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是必須的,但是老年代和永久代並不是必須的,可以通過設置參數來決定是否對類進行回收
 
下面是畫的一個大概的圖片。
 
 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM