溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java中怎么實現(xiàn)一個分代收集算法

發(fā)布時間:2021-06-17 11:25:06 來源:億速云 閱讀:143 作者:Leah 欄目:編程語言

這篇文章給大家介紹Java中怎么實現(xiàn)一個分代收集算法,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

概述

這種算法,根據對象的存活周期的不同將內存劃分成幾塊,新生代和老年代,這樣就可以根據各個年代的特點采用最適當的收集算法??梢杂米ブ攸c的思路來理解這個算法。

新生代對象朝生夕死,對象數量多,只要重點掃描這個區(qū)域,那么就可以大大提高垃圾收集的效率。另外老年代對象存儲久,無需經常掃描老年代,避免掃描導致的開銷。

新生代

在新生代,每次垃圾收集器都發(fā)現(xiàn)有大批對象死去,只有少量存活,采用復制算法,只需要付出少量存活對象的復制成本就可以完成收集;可以參看我之前寫的Java垃圾回收之復制算法詳解

老年代

而老年代中因為對象存活率高、沒有額外空間對它進行分配擔保,就必須“標記-清除-壓縮”算法進行回收。參看Java垃圾回收之標記壓縮算法詳解

新創(chuàng)建的對象被分配在新生代,如果對象經過幾次回收后仍然存活,那么就把這個對象劃分到老年代。

老年代區(qū)存放Young區(qū)Survivor滿后觸發(fā)minor GC后仍然存活的對象,當Eden區(qū)滿后會將存活的對象放入Survivor區(qū)域,如果Survivor區(qū)存不下這些對象,GC收集器就會將這些對象直接存放到Old區(qū)中,如果Survivor區(qū)中的對象足夠老,也直接存放到Old區(qū)中。如果Old區(qū)滿了,將會觸發(fā)Full GC回收整個堆內存。

永久代:(即方法區(qū)回收)

JVM的方法區(qū),也被稱為永久代。在這里都是放著一些被虛擬機加載的類信息,靜態(tài)變量,常量等數據。這個區(qū)中的東西比老年代和新生代更不容易回收。

  • 效率:復制算法>標記壓縮算法>標記清除算法(此處的效率只是簡單的對比時間復雜度,實際情況不一定如此)。

  • 內存整齊度:復制算法=標記壓縮算法>標記清除算法。

  • 內存利用率:標記壓縮算法=標記清除算法>復制算法。

關于Java中怎么實現(xiàn)一個分代收集算法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI