這篇文章主要介紹了2020面試阿里位元組跳動90%被問到的JVM面試題附答案,小編在網上看到覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧!
最近老是收到小夥伴的私信問我能不能幫忙整理出一份JVM相關的面試題出來,說自己在大廠去面試的時候這一塊問的是特別多的,每次自己學的時候每次都學不到重點去。這不他來了,一份詳細的JVM面試真題給大家整理在下方了!
另外本人整理收藏了20年多家公司面試知識點整理 共127頁的PDF 以及各種知識點整理 免費分享給大家,想要資料的話點選795983544 暗號CSDN,或者私信我,暗號PDF。
1、棧是執行緒私有的,棧的生命週期和執行緒一樣,每個方法在執行的時候就會建立一個棧幀,它包含區域性變數表、運算元棧、動態連結、方法出口等資訊,區域性變數表又包括基本資料型別和物件的參照;
2、當執行緒請求的棧深度超過了虛擬機器器允許的最大深度時,會丟擲StackOverFlowError異常,方法遞迴呼叫肯可能會出現該問題;
3、調整引數-xss去調整jvm棧的大小
jvm將虛擬機器器分為5大區域,程式計數器、虛擬機器器棧、本地方法棧、java堆、方法區;
java堆 = 新生代+老年代;新生代 = Eden + Suivivor(S0 + S1),預設分配比例是8:1:1;當Eden區空間滿了的時候,就會觸發一次Minor GC,以收集新生代的垃圾,存活下來的物件會被分配到Survivor區大物件(需要大量連續記憶體空間的物件)會直接被分配到老年代如果物件在Eden中出生,並且在經歷過一次Minor GC之後仍然存活,被分配到存活區的話,年齡+1,此後每經歷過一次Minor GC並且存活下來,年齡就+1,當年齡達到15的時候,會被晉升到老年代;當老年代滿了,而無法容納更多物件的話,會觸發一次full gc;full gc儲存的是整個記憶體堆(包括年輕代和老年代);;Major GC是發生在老年代的GC,清理老年區,經常會伴隨至少一次minor gc;
java中有四種垃圾回收演演算法,分別是標記清除法、標記整理法、複製演演算法、分代收集演演算法;
判斷一個物件是否存活,分為兩種演演算法1:參照計數法;2:可達性分析演演算法;
參照計數法:給每一個物件設定一個參照計數器,當有一個地方參照該物件的時候,參照計數器就+1,參照失效時,參照計數器就-1;當參照計數器為0的時候,就說明這個物件沒有被參照,也就是垃圾物件,等待回收;缺點:無法解決迴圈參照的問題,當A參照B,B也參照A的時候,此時AB物件的參照都不為0,此時也就無法垃圾回收,所以一般主流虛擬機器器都不採用這個方法;
可達性分析法從一個被稱為GC Roots的物件向下搜尋,如果一個物件到GC Roots沒有任何參照鏈相連線時,說明此物件不可用,在java中可以作為GC Roots的物件有以下幾種:
虛擬機器器棧中參照的物件方法區類靜態屬性參照的變數方法區常數池參照的物件本地方法棧JNI參照的物件但一個物件滿足上述條件的時候,不會馬上被回收,還需要進行兩次標記;第一次標記:判斷當前物件是否有finalize()方法並且該方法沒有被執行過,若不存在則標記為垃圾物件,等待回收;若有的話,則進行第二次標記;第二次標記將當前物件放入F-Queue佇列,並生成一個finalize執行緒去執行該方法,虛擬機器器不保證該方法一定會被執行,這是因為如果執行緒執行緩慢或進入了死鎖,會導致回收系統的崩潰;如果執行了finalize方法之後仍然沒有與GC Roots有直接或者間接的參照,則該物件會被回收;
垃圾回收器主要分為以下幾種:Serial、ParNew、Parallel Scavenge、Serial Old、Parallel Old、CMS、G1;
虛擬機器器把描述類的資料載入到記憶體裡面,並對資料進行校驗、解析和初始化,最終變成可以被虛擬機器器直接使用的class物件;
主要分為以下幾個過程:載入、驗證、準備、解析、初始化;載入:載入分為三步:
1、通過類的全限定性類名獲取該類的二進位制流;
2、將該二進位制流的靜態儲存結構轉為方法區的執行時資料結構;
3、在堆中為該類生成一個class物件;
驗證:驗證該class檔案中的位元組流資訊複合虛擬機器器的要求,不會威脅到jvm的安全;
準備:為class物件的靜態變數分配記憶體,初始化其初始值;
解析:該階段主要完成符號參照轉化成直接參照;
初始化:到了初始化階段,才開始執行類中定義的java程式碼;初始化階段是呼叫類構造器的過程;
類載入器是指:通過一個類的全限定性類名獲取該類的二進位制位元組流叫做類載入器;類載入器分為以下四種:啟動類載入器:用來載入java核心類庫,無法被java程式直接參照;
擴充套件類載入器:用來載入java的擴充套件庫,java的虛擬機器器實現會提供一個擴充套件庫目錄,該類載入器在擴充套件庫目錄裡面查詢並載入java類;
系統類載入器:它根據java的類路徑來載入類,一般來說,java應用的類都是通過它來載入的;
自定義類載入器:由java語言實現,繼承自ClassLoader;
當一個類載入器收到一個類載入的請求,他首先不會嘗試自己去載入,而是將這個請求委派給父類別載入器去載入,只有父類別載入器在自己的搜尋範圍類查詢不到給類時,子載入器才會嘗試自己去載入該類;
為了防止記憶體中出現多個相同的位元組碼;因為如果沒有雙親委派的話,使用者就可以自己定義一個java.lang.String類,那麼就無法保證類的唯一性;
自定義類載入器,繼承ClassLoader類,重寫loadClass方法和findClass方法;
強參照:強參照是我們使用最廣泛的參照,如果一個物件具有強參照,那麼垃圾回收期絕對不會回收它,當記憶體空間不足時,垃圾回收器寧願丟擲OutOfMemoryError,也不會回收具有強參照的物件;我們可以通過顯示的將強參照物件置為null,讓gc認為該物件不存在參照,從而來回收它;
軟參照:軟應用是用來描述一些有用但不是必須的物件,在java中用SoftReference來表示,當一個物件只有軟應用時,只有當記憶體不足時,才會回收它;軟參照可以和參照佇列聯合使用,如果軟參照所參照的物件被垃圾回收器所回收了,虛擬機器器會把這個軟參照加入到與之對應的參照佇列中;
弱參照:弱參照是用來描述一些可有可無的物件,在java中用WeakReference來表示,在垃圾回收時,一旦發現一個物件只具有軟參照的時候,無論當前記憶體空間是否充足,都會回收掉該物件;弱參照可以和參照佇列聯合使用,如果弱參照所參照的物件被垃圾回收了,虛擬機器器會將該物件的參照加入到與之關聯的參照佇列中;
虛參照:虛參照就是一種可有可無的參照,無法用來表示物件的生命週期,任何時候都可能被回收,虛參照主要使用來跟蹤物件被垃圾回收的活動,虛參照和軟參照與弱參照的區別在於:虛參照必須和參照佇列聯合使用;在進行垃圾回收的時候,如果發現一個物件只有虛參照,那麼就會將這個物件的參照加入到與之關聯的參照佇列中,程式可以通過發現一個參照佇列中是否已經加入了虛參照,來了解被參照的物件是否需要被進行垃圾回收;
到此這篇關於2020面試阿里位元組跳動90%被問到的JVM面試題附答案的文章就介紹到這了,更多相關JVM面試題內容請搜尋我以前的文章或繼續瀏覽下面的相關文章!
另外本人整理收藏了20年多家公司面試知識點整理 共127頁的PDF 以及各種知識點整理 免費分享給大家,想要資料的話點選795983544 暗號CSDN,或者私信我,暗號PDF。 深入底層,剖析原始碼。瞭解本質。 愛程式設計,愛生活,愛分享!文章的最後祝大家在工作的工作順利,在找工作的都能拿到自己滿意的offer!