這篇文章給大家介紹Java中怎么實現(xiàn)一個分代收集算法,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
站在用戶的角度思考問題,與客戶深入溝通,找到宜陽網(wǎng)站設(shè)計與宜陽網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:網(wǎng)站設(shè)計制作、成都網(wǎng)站設(shè)計、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、空間域名、網(wǎng)頁空間、企業(yè)郵箱。業(yè)務(wù)覆蓋宜陽地區(qū)。概述
這種算法,根據(jù)對象的存活周期的不同將內(nèi)存劃分成幾塊,新生代和老年代,這樣就可以根據(jù)各個年代的特點采用最適當(dāng)?shù)氖占惴???梢杂米ブ攸c的思路來理解這個算法。
新生代對象朝生夕死,對象數(shù)量多,只要重點掃描這個區(qū)域,那么就可以大大提高垃圾收集的效率。另外老年代對象存儲久,無需經(jīng)常掃描老年代,避免掃描導(dǎo)致的開銷。
新生代
在新生代,每次垃圾收集器都發(fā)現(xiàn)有大批對象死去,只有少量存活,采用復(fù)制算法,只需要付出少量存活對象的復(fù)制成本就可以完成收集;可以參看我之前寫的Java垃圾回收之復(fù)制算法詳解
老年代
而老年代中因為對象存活率高、沒有額外空間對它進(jìn)行分配擔(dān)保,就必須“標(biāo)記-清除-壓縮”算法進(jìn)行回收。參看Java垃圾回收之標(biāo)記壓縮算法詳解
新創(chuàng)建的對象被分配在新生代,如果對象經(jīng)過幾次回收后仍然存活,那么就把這個對象劃分到老年代。
老年代區(qū)存放Young區(qū)Survivor滿后觸發(fā)minor GC后仍然存活的對象,當(dāng)Eden區(qū)滿后會將存活的對象放入Survivor區(qū)域,如果Survivor區(qū)存不下這些對象,GC收集器就會將這些對象直接存放到Old區(qū)中,如果Survivor區(qū)中的對象足夠老,也直接存放到Old區(qū)中。如果Old區(qū)滿了,將會觸發(fā)Full GC回收整個堆內(nèi)存。
永久代:(即方法區(qū)回收)
JVM的方法區(qū),也被稱為永久代。在這里都是放著一些被虛擬機(jī)加載的類信息,靜態(tài)變量,常量等數(shù)據(jù)。這個區(qū)中的東西比老年代和新生代更不容易回收。
效率:復(fù)制算法>標(biāo)記壓縮算法>標(biāo)記清除算法(此處的效率只是簡單的對比時間復(fù)雜度,實際情況不一定如此)。
內(nèi)存整齊度:復(fù)制算法=標(biāo)記壓縮算法>標(biāo)記清除算法。
內(nèi)存利用率:標(biāo)記壓縮算法=標(biāo)記清除算法>復(fù)制算法。
關(guān)于Java中怎么實現(xiàn)一個分代收集算法就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
網(wǎng)站題目:Java中怎么實現(xiàn)一個分代收集算法-創(chuàng)新互聯(lián)
文章起源:http://aaarwkj.com/article34/gjhpe.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供做網(wǎng)站、網(wǎng)站設(shè)計公司、云服務(wù)器、App開發(fā)、面包屑導(dǎo)航、標(biāo)簽優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容