淺析JVM垃圾回收的過程
JVM垃圾回收的算法很多,但是不管是哪種算法,在進(jìn)行GC時(shí)大致的流程都是差不多的,主要有以下3個(gè)過程:
1. 枚舉根節(jié)點(diǎn)
這個(gè)過程主要是找到所有的GC Roots對象,這些對象一般發(fā)生在JVM虛擬機(jī)棧棧幀、常量池中的靜態(tài)對象、方法區(qū)中靜態(tài)類屬性引用、本地方法棧中引用的對象。這個(gè)過程會(huì)發(fā)生STW,所有的線程均運(yùn)行到安全區(qū)域(Safe Region)才開始執(zhí)行。
通常有兩種算法:
- 引用計(jì)數(shù)法:每個(gè)對象中添加一個(gè)引用計(jì)數(shù)器,每當(dāng)有一個(gè)地方引用它時(shí),計(jì)數(shù)器值就+1;當(dāng)引用失效時(shí),計(jì)數(shù)器值就-1;任何時(shí)刻計(jì)數(shù)器為0的對象就是不可能在被使用的。
優(yōu)點(diǎn)是效率高,缺點(diǎn)是循環(huán)引用無法處理,導(dǎo)致內(nèi)存溢出。
- 可達(dá)性分析:以GC Roots為根節(jié)點(diǎn),從這些根節(jié)點(diǎn)開始向下搜索,搜索所走過的路徑稱為引用鏈(Reference Chain),當(dāng)一個(gè)對象不在任何引用鏈相連時(shí),則證明此對象是不可用的。
優(yōu)點(diǎn)可以檢測所有的對象,缺點(diǎn)效率低。
GC Roots節(jié)點(diǎn)一般為:
- 虛擬機(jī)棧中棧幀引用的對象
- 本地方法棧JNI中棧幀引用的對象
- 常量池中引用的對象
- 類中的靜態(tài)變量應(yīng)用的對象
2. 標(biāo)記
標(biāo)記的過程主要是標(biāo)記哪些對象是需要被回收的,有的GC算法是并行的,有的是和GC Roots標(biāo)記一起執(zhí)行。如果是并行的,不會(huì)發(fā)生STW。
如果是并發(fā)標(biāo)記的GC算法,后面還有有一次重新標(biāo)記或者最終標(biāo)記。這主要是來解決在并發(fā)標(biāo)記的過程中,用戶線程還在一直執(zhí)行,這期間有變化的對象。
標(biāo)記算法常見的有兩種:
- 標(biāo)記–清除算法或者標(biāo)記–整理算法:為每個(gè)對象存儲(chǔ)一個(gè)標(biāo)記位,記錄對象的狀態(tài)(活著或是死亡)
- 復(fù)制算法:將內(nèi)存平均分成兩部分,然后每次只使用其中的一部分,當(dāng)這部分內(nèi)存滿的時(shí)候,將內(nèi)存中所有存活的對象復(fù)制到另一個(gè)內(nèi)存中,然后將之前的內(nèi)存中死亡的對象清空。
3. 清除或回收
這個(gè)階段會(huì)根據(jù)GC算法的不同采取不同的回收策略。
- CMS算法在回收的時(shí)候會(huì)考慮停頓時(shí)間,盡量減少GC線程占用的時(shí)間
- G1算法先對各個(gè)Region的回收價(jià)值和成本進(jìn)行排序,根據(jù)用戶所期望的GC停頓時(shí)間來制定回收計(jì)劃
- 標(biāo)記-清除算法在第二階段(清除階段)將對象回收
- 復(fù)制算法是通過將存活對象復(fù)制到另一塊內(nèi)存區(qū)域,將當(dāng)前區(qū)域中未被復(fù)制的對象進(jìn)行清除
以上就是淺析JVM垃圾回收的過程的詳細(xì)內(nèi)容,更多關(guān)于JVM垃圾回收的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Spring Cloud Gateway 攔截響應(yīng)問題分析(數(shù)據(jù)截?cái)鄦栴})
這篇文章主要介紹了Spring Cloud Gateway 攔截響應(yīng)問題分析(數(shù)據(jù)截?cái)鄦栴}),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-01-01java虛擬機(jī)學(xué)習(xí)筆記進(jìn)階篇
在本篇內(nèi)容里小編給大家分享了關(guān)于java虛擬機(jī)學(xué)習(xí)筆記的進(jìn)階內(nèi)容,需要的朋友們跟著學(xué)習(xí)下。2019-06-06如何使用Springfox?Swagger實(shí)現(xiàn)API自動(dòng)生成單元測試
Springfox是一個(gè)使用Java語言開發(fā)開源的API Doc的框架,它的前身是swagger-springmvc,可以將我們的Controller中的方法以文檔的形式展現(xiàn),這篇文章主要介紹了如何使用Springfox?Swagger實(shí)現(xiàn)API自動(dòng)生成單元測試,感興趣的朋友跟隨小編一起看看吧2024-04-04SpringCloud Ribbon負(fù)載均衡實(shí)例解析
這篇文章主要介紹了SpringCloud Ribbon負(fù)載均衡實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11