更新時間:2020-04-17 15:08:31 來源:動力節(jié)點 瀏覽3624次
ThreadLocal(線程變量副本)
Synchronized實現(xiàn)內(nèi)存共享,ThreadLocal為每個線程維護一個本地變量。
采用空間換時間,它用于線程間的數(shù)據(jù)隔離,為每一個使用該變量的線程提供一個副本,每個線程都可以獨立地改變自己的副本,而不會和其他線程的副本沖突。
ThreadLocal類中維護一個Map,用于存儲每一個線程的變量副本,Map中元素的鍵為線程對象,而值為對應(yīng)線程的變量副本。
ThreadLocal在Spring中發(fā)揮著巨大的作用,在管理Request作用域中的Bean、事務(wù)管理、任務(wù)調(diào)度、AOP等模塊都出現(xiàn)了它的身影。
Spring中絕大部分Bean都可以聲明成Singleton作用域,采用ThreadLocal進行封裝,因此有狀態(tài)的Bean就能夠以singleton的方式在多線程中正常工作了。
Java內(nèi)存模型:
Java虛擬機規(guī)范中將Java運行時數(shù)據(jù)分為六種。
1.程序計數(shù)器:是一個數(shù)據(jù)結(jié)構(gòu),用于保存當(dāng)前正常執(zhí)行的程序的內(nèi)存地址。Java虛擬機的多線程就是通過線程輪流切換并分配處理器時間來實現(xiàn)的,為了線程切換后能恢復(fù)到正確的位置,每條線程都需要一個獨立的程序計數(shù)器,互不影響,該區(qū)域為“線程私有”。
2.Java虛擬機棧:線程私有的,與線程生命周期相同,用于存儲局部變量表,操作棧,方法返回值。局部變量表放著基本數(shù)據(jù)類型,還有對象的引用。
3.本地方法棧:跟虛擬機棧很像,不過它是為虛擬機使用到的Native方法服務(wù)。
4.Java堆:所有線程共享的一塊內(nèi)存區(qū)域,對象實例幾乎都在這分配內(nèi)存。
5.方法區(qū):各個線程共享的區(qū)域,儲存虛擬機加載的類信息,常量,靜態(tài)變量,編譯后的代碼。
6.運行時常量池:代表運行時每個class文件中的常量表。包括幾種常量:編譯時的數(shù)字常量、方法或者域的引用。
“你能不能談?wù)?,javaGC是在什么時候,對什么東西,做了什么事情?”
在什么時候:
1.新生代有一個Eden區(qū)和兩個survivor區(qū),首先將對象放入Eden區(qū),如果空間不足就向其中的一個survivor區(qū)上放,如果仍然放不下就會引發(fā)一次發(fā)生在新生代的minorGC,將存活的對象放入另一個survivor區(qū)中,然后清空Eden和之前的那個survivor區(qū)的內(nèi)存。在某次GC過程中,如果發(fā)現(xiàn)仍然又放不下的對象,就將這些對象放入老年代內(nèi)存里去。
2.大對象以及長期存活的對象直接進入老年區(qū)。
3.當(dāng)每次執(zhí)行minorGC的時候應(yīng)該對要晉升到老年代的對象進行分析,如果這些馬上要到老年區(qū)的老年對象的大小超過了老年區(qū)的剩余大小,那么執(zhí)行一次FullGC以盡可能地獲得老年區(qū)的空間。
對什么東西:從GCRoots搜索不到,而且經(jīng)過一次標記清理之后仍沒有復(fù)活的對象。
做什么:
新生代:復(fù)制清理;
老年代:標記-清除和標記-壓縮算法;
永久代:存放Java中的類和加載類的類加載器本身。
GCRoots都有哪些:
1.虛擬機棧中的引用的對象
2.方法區(qū)中靜態(tài)屬性引用的對象,常量引用的對象
3.本地方法棧中JNI(即一般說的Native方法)引用的對象。
Synchronized與Lock都是可重入鎖,同一個線程再次進入同步代碼的時候.可以使用自己已經(jīng)獲取到的鎖。
Synchronized是悲觀鎖機制,獨占鎖。而Locks.ReentrantLock是,每次不加鎖而是假設(shè)沒有沖突而去完成某項操作,如果因為沖突失敗就重試,直到成功為止。
ReentrantLock適用場景
某個線程在等待一個鎖的控制權(quán)的這段時間需要中斷
需要分開處理一些wait-notify,ReentrantLock里面的Condition應(yīng)用,能夠控制notify哪個線程,鎖可以綁定多個條件。
具有公平鎖功能,每個到來的線程都將排隊等候。
友情鏈接:Synchronized關(guān)鍵字、Lock,并解釋它們之間的區(qū)別
StringBuffer是線程安全的,每次操作字符串,String會生成一個新的對象,而StringBuffer不會;StringBuilder是非線程安全的
fail-fast:機制是java集合(Collection)中的一種錯誤機制。當(dāng)多個線程對同一個集合的內(nèi)容進行操作時,就可能會產(chǎn)生fail-fast事件。
例如:當(dāng)某一個線程A通過iterator去遍歷某集合的過程中,若該集合的內(nèi)容被其他線程所改變了;那么線程A訪問集合時,就會拋出ConcurrentModificationException異常,產(chǎn)生fail-fast事件
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.傳遞性:如果Ahappens-beforeB,且Bhappens-beforeC,那么Ahappens-beforeC。
5.線程啟動規(guī)則:Thread對象的start()方法happens-before于此線程的每一個動作。

以上就是動力節(jié)點java培訓(xùn)機構(gòu)的小編針對“各大互聯(lián)網(wǎng)java后端開發(fā)筆試題”的內(nèi)容進行的回答,希望對大家有所幫助,如有疑問,請在線咨詢,有專業(yè)老師隨時為你服務(wù)。
相關(guān)閱讀