淺談Java GC分代的緣由

Java GC(garbage collec,垃圾收集,回收)
GC是對JVM中的內存進行標記和回收,Sun公司的JDK用的虛擬機都是HotSpot,對象化的實例是放在heap堆內存中的,這裏講的分代收集也是指對堆內存的回收。
GC的分代收集分爲:年輕代、老年代、永久代。(方法區是被當作永久代的,不過JDK1.6後將被取消掉了)
年輕代(Young Generation)、年老代(Old Generation)、永久代(Permanent Generation,也就是方法區)
1.年輕代的GC(存放實例化的對象)
年輕代分爲三個區:Eden和兩個存活區(Survivor0和Survivor1),分別佔內存的80%、10%、10%
使用「中止-複製(Stop-and-copy)」清理法(將Eden區和一個Survivor中仍然存活的對象拷貝到另外一個Survivor中)
當Eden區滿時,就執行一次MinorGC,並將剩餘存活的對象都添加到Surivivor0,回收Eden中的沒有存活的對象。
當Surivivor0頁都滿了的時候,就將仍然存活的存到Surivivor1中,回收Surivivor0中的對象
Surivivor0和Surivivor1依次去存,當兩個存活區切換了幾回後(HotSpot默認是15次),將仍然存活的對象複製到老年代。
2.老年代的GC(存放較大的實例化的對象和在年輕代中存活了足夠久的對象)
老年代GC用的是標記-整理算法,即標記存活的對象,向一端移動,保證內存的完整性,而後將未標記的清掉。
當老年代不夠用時,也會執行Major GC,即Full GC。
注意:若是永久代代存放的常量和類過大,沒法所有放入永久代,也會觸發永久代的GC,將一部分放入老年代。
3.永久代的GC(存放常量、類)
說明:在JDK1.6版本以後,永久代就要被取消掉了,只留下年輕代和老年代。
說明:年輕代的GC是必須的,可是老年代和永久代並非必須的,能夠經過設置參數來決定是否對類進行回收。算法

下面是畫的一個大概的圖片:對象

相關文章
相關標籤/搜索