這篇文章主要講解了“jvm垃圾回收機(jī)制的原理”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“jvm垃圾回收機(jī)制的原理”吧!
網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)公司!專(zhuān)注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、重慶小程序開(kāi)發(fā)公司、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶(hù)創(chuàng)新互聯(lián)還提供了南城免費(fèi)建站歡迎大家使用!
垃圾回收機(jī)制原理:
jvm如何判斷一個(gè)對(duì)象是不是垃圾?
使用可達(dá)性分析法去對(duì)一個(gè)GC roots對(duì)象進(jìn)行分析,從一個(gè)節(jié)點(diǎn)GC ROOT 開(kāi)始,尋找對(duì)應(yīng)的引用節(jié)點(diǎn),找到這個(gè)節(jié)點(diǎn)以后,繼續(xù)尋找這個(gè)節(jié)點(diǎn)的引用節(jié)點(diǎn),當(dāng)所有的引用節(jié)點(diǎn)尋找完畢之后,剩余的節(jié)點(diǎn)則被認(rèn)為是沒(méi)有被引用到的節(jié)點(diǎn),即無(wú)用的節(jié)點(diǎn)也就是垃圾。
java 中可作為 GC Root 的對(duì)象有:
1.虛擬機(jī)棧中引用的對(duì)象(本地變量表)
2.方法區(qū)中靜態(tài)屬性引用的對(duì)象
3. 方法區(qū)中常量引用的對(duì)象
4.本地方法棧中引用的對(duì)象(Native 對(duì)象)
對(duì)垃圾進(jìn)行回收的垃圾回收算法:
1.Mark-Sweep(標(biāo)記-清除)算法
這是最基礎(chǔ)的垃圾回收算法,之所以說(shuō)它是最基礎(chǔ)的是因?yàn)樗钊菀讓?shí)現(xiàn),思想也是最簡(jiǎn)單的。標(biāo)記-清除算法分為兩個(gè)階段:標(biāo)記階段和清除階段。標(biāo)記階段的任務(wù)是標(biāo)記出所有需要被回收的對(duì)象,清除階段就是回收被標(biāo)記的對(duì)象所占用的空間。標(biāo)記-清除算法實(shí)現(xiàn)起來(lái)比較容易,但是有一個(gè)比較嚴(yán)重的問(wèn)題就是容易產(chǎn)生內(nèi)存碎片,碎片太多可能會(huì)導(dǎo)致后續(xù)過(guò)程中需要為大對(duì)象分配空間時(shí)無(wú)法找到足夠的空間而提前觸發(fā)新的一次垃圾收集動(dòng)作。
2.Copying(復(fù)制)算法 新生代GC算法
它將可用內(nèi)存按容量劃分為大小相等的兩塊,每次只使用其中的一塊。當(dāng)這一塊的內(nèi)存用完了,就將還存活著的對(duì)象復(fù)制到另外一塊上面,然后再把已使用的內(nèi)存空間一次清理掉,這樣一來(lái)就不容易出現(xiàn)內(nèi)存碎片的問(wèn)題。
這種算法雖然實(shí)現(xiàn)簡(jiǎn)單,運(yùn)行高效且不容易產(chǎn)生內(nèi)存碎片,但是卻對(duì)內(nèi)存空間的使用做出了高昂的代價(jià),因?yàn)槟軌蚴褂玫膬?nèi)存縮減到原來(lái)的一半。
很顯然,Copying 算法的效率跟存活對(duì)象的數(shù)目多少有很大的關(guān)系,如果存活對(duì)象很多,
那么 Copying 算法的效率將會(huì)大大降低。
在復(fù)制算法中,當(dāng)?shù)诙€(gè)步驟往復(fù)一次,jvm內(nèi)對(duì)象年齡加一,當(dāng)jvm往返15次,年齡達(dá)到15時(shí),新生代會(huì)轉(zhuǎn)為老年代。
3.Mark-Compact(標(biāo)記-整理)算法
標(biāo)記整理算法在標(biāo)記清除方法的基礎(chǔ)之上,也就是先對(duì)垃圾進(jìn)行標(biāo)記清除之后,再使存活對(duì)象向另一側(cè)移動(dòng),進(jìn)行整理。
4.Generational Collection(分代收集)算法
分代收集算法是目前大部分 JVM 的垃圾收集器采用的算法。它的核心思想是根據(jù)對(duì)象存活的生命周期將內(nèi)存劃分為若干個(gè)不同的區(qū)域。一般情況下將堆區(qū)劃分為老年代(TenuredGeneration)和新生代(Young Generation),老年代的特點(diǎn)是每次垃圾收集時(shí)只有少量對(duì)象需要被回收,而新生代的特點(diǎn)是每次垃圾回收時(shí)都有大量的對(duì)象需要被回收,那么就可以根據(jù)不同代的特點(diǎn)采取最適合的收集算法。
對(duì)于新生代采取標(biāo)記復(fù)制算法,因?yàn)樾律忻看卫厥斩家厥沾蟛糠謱?duì)象,也就是說(shuō)需要復(fù)制的操作次數(shù)較少,但是實(shí)際中并不是按照 1:1 的比例來(lái)劃分新生代的空間的,一般來(lái)說(shuō)是將新生代劃分為一塊較大的 Eden 空間和兩塊較小的Survivor 空間,每次使用 Eden 空間和其中的一塊 Survivor 空間,當(dāng)進(jìn)行回收時(shí),將 Eden和 Survivor 中還存活的對(duì)象復(fù)制到另一塊 Survivor 空間中,然后清理掉 Eden 和剛才使用過(guò)的 Survivor 空間。
老年代的特點(diǎn)是每次回收都只回收少量對(duì)象,所以使用標(biāo)記整理算法。
注意,在堆區(qū)之外還有一個(gè)代就是永久代(Permanet Generation),它用來(lái)存儲(chǔ) class類(lèi)、常量、方法描述等。
對(duì)永久代的回收主要回收兩部分內(nèi)容:廢棄常量和無(wú)用的類(lèi)。
感謝各位的閱讀,以上就是“jvm垃圾回收機(jī)制的原理”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)jvm垃圾回收機(jī)制的原理這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!