更新時間:2019-12-06 15:09:03 來源:動力節(jié)點 瀏覽2579次
ThreadLocal(線程變量副本)
Synchronized實現(xiàn)內(nèi)存共享,ThreadLocal為每個線程維護(hù)一個本地變量。
采用空間換時間,它用于線程間的數(shù)據(jù)隔離,為每一個使用該變量的線程提供一個副本,每個線程都可以獨立地改變自己的副本,而不會和其他線程的副本沖突。
ThreadLocal類中維護(hù)一個Map,用于存儲每一個線程的變量副本,Map中元素的鍵為線程對象,而值為對應(yīng)線程的變量副本。
ThreadLocal在Spring中發(fā)揮著巨大的作用,在管理Request作用域中的Bean、事務(wù)管理、任務(wù)調(diào)度、AOP等模塊都出現(xiàn)了它的身影。
Spring中絕大部分Bean都可以聲明成Singleton作用域,采用ThreadLocal進(jìn)行封裝,因此有狀態(tài)的Bean就能夠以singleton的方式在多線程中正常工作了。
“你能不能談?wù)劊琷ava GC是在什么時候,對什么東西,做了什么事情?”
在什么時候:
1、新生代有一個Eden區(qū)和兩個survivor區(qū),首先將對象放入Eden區(qū),如果空間不足就向其中的一個survivor區(qū)上放,如果仍然放不下就會引發(fā)一次發(fā)生在新生代的minor GC,將存活的對象放入另一個survivor區(qū)中,然后清空Eden和之前的那個survivor區(qū)的內(nèi)存。在某次GC過程中,如果發(fā)現(xiàn)仍然又放不下的對象,就將這些對象放入老年代內(nèi)存里去。
2、大對象以及長期存活的對象直接進(jìn)入老年區(qū)。
3、當(dāng)每次執(zhí)行minor GC的時候應(yīng)該對要晉升到老年代的對象進(jìn)行分析,如果這些馬上要到老年區(qū)的老年對象的大小超過了老年區(qū)的剩余大小,那么執(zhí)行一次Full GC以盡可能地獲得老年區(qū)的空間。
對什么東西:
從GC Roots搜索不到,而且經(jīng)過一次標(biāo)記清理之后仍沒有復(fù)活的對象。
做什么:
新生代:復(fù)制清理; 老年代:標(biāo)記-清除和標(biāo)記-壓縮算法; 永久代:存放Java中的類和加載類的類加載器本身。
GC Roots都有哪些: 1. 虛擬機棧中的引用的對象 2. 方法區(qū)中靜態(tài)屬性引用的對象,常量引用的對象 3. 本地方法棧中JNI(即一般說的Native方法)引用的對象。
Synchronized 與Loc
Synchronized 與Lock都是可重入鎖,同一個線程再次進(jìn)入同步代碼的時候。可以使用自己已經(jīng)獲取到的鎖。
Synchronized是悲觀鎖機制,獨占鎖。而Locks.ReentrantLock是,每次不加鎖而是假設(shè)沒有沖突而去完成某項操作,如果因為沖突失敗就重試,直到成功為止。
ReentrantLock適用場景
1、某個線程在等待一個鎖的控制權(quán)的這段時間需要中斷;
2、需要分開處理一些wait-notify,ReentrantLock里面的Condition應(yīng)用,能夠控制notify哪個線程,鎖可以綁定多個條件;
3、具有公平鎖功能,每個到來的線程都將排隊等候。
StringBuffer是線程安全的,每次操作字符串,String會生成一個新的對象,而StringBuffer不會;StringBuilder是非線程安全的。
fail-fast是什么?
fail-fast:機制是java集合(Collection)中的一種錯誤機制。當(dāng)多個線程對同一個集合的內(nèi)容進(jìn)行操作時,就可能會產(chǎn)生fail-fast事件。
例如:當(dāng)某一個線程A通過iterator去遍歷某集合的過程中,若該集合的內(nèi)容被其他線程所改變了;那么線程A訪問集合時,就會拋出ConcurrentModificationException異常,產(chǎn)生fail-fast事件。
happens-before
happens-before:如果兩個操作之間具有 happens-before 關(guān)系,那么前一個操作的結(jié)果就會對后面一個操作可見。
1、程序順序規(guī)則:一個線程中的每個操作,happens- before 于該線程中的任意后續(xù)操作。
2、監(jiān)視器鎖規(guī)則:對一個監(jiān)視器鎖的解鎖,happens- before 于隨后對這個監(jiān)視器鎖的加鎖。
3、volatile變量規(guī)則:對一個volatile域的寫,happens- before于任意后續(xù)對這個volatile域的讀。
4、傳遞性:如果A happens- before B,且B happens- before C,那么A happens- before C。
5、線程啟動規(guī)則:Thread對象的start()方法happens- before于此線程的每一個動作。
Volatile和Synchronized的不同點
Volatile和Synchronized四個不同點:
1、粒度不同,前者針對變量 ,后者鎖對象和類;
2、syn阻塞,volatile線程不阻塞;
3、syn保證三大特性,volatile不保證原子性;
4、syn編譯器優(yōu)化,volatile不優(yōu)化 volatile具備兩種特性:
保證此變量對所有線程的可見性,指一條線程修改了這個變量的值,新值對于其他線程來說是可見的,但并不是多線程安全的;
禁止指令重排序優(yōu)化。
以上就是動力節(jié)點Java培訓(xùn)機構(gòu)小編介紹的“2020年用到的Java面試資料”的內(nèi)容,希望對大家有幫助,如有疑問,請在線咨詢,有專業(yè)老師隨時為你服務(wù)。
相關(guān)推薦
最新最全java面試題及答案(初級到高級)
相關(guān)閱讀
初級 202925
初級 203221
初級 202629
初級 203743