1.產生的過程
對象被jvm垃圾回收,隨著對象熬過垃圾收集過程的次數(這里叫為對象的年齡)
依據回收對象的年齡將對象分配到不同的java堆區域;
1.弱分代假說: 認為大多數對象都是朝生夕死 --> 年輕代
2.強分代假說: 對象年齡越大越難被回收 ---> 老年代
3.跨代引用假說: 存在年輕代與老年代相互循環引用,應該傾向于同時生存與同時消亡
跨代引用的具體操作:
1.在年輕代上建立一個全局數據結構 (記憶集 remembered set)
2.數據結構把老年代劃分為若干小塊,標出哪一塊內存會存在跨代引用
3.Minor Gc時, 將包含了跨代引用的小塊內存計入到GC Roots進行掃描
備注: 部分掃描總是優于全局掃描
2.java堆區域的劃分
年輕代:(Young Gen)
大小:
隨堆大小的增大和減小而相應的變化,默認值是保持為堆大小的1/15
-Xmn 參數設置年輕代為固定大小
-XX:NewRatio 來設置年輕代與年老代的大小比例
特點:
年輕代用來存放新近創建的對象
產生大量的死亡對象,并且要是產生連續可用的空間
使用標記-復制,標記-清除 算法和并行收集器進行垃圾回收
對年輕代的垃圾回收稱作初級回收 (minor gc)
區域劃分:
一個新生代 Eden
2個大小相同的復活代 S0 S1
回收過程:
1.應用程序只能使用一個新生代和一個復活代,
2.當發生初級垃圾回收的時候,gc掛起程序,
3.然后將新生代和復活代中的存活對象復制到另外一個非活動的復活代中,
4.然后一次性清除新生代和復活代,將原來的非復活代標記成為活動復活代。
5.將在指定次數回收后仍然存在的對象移動到老年代中,
6.初級回收后,得到一個空的可用的新生代。
具體描述:
1.對象在 Eden 出生后,在經過一次 Minor GC 后
2.如果對象還存活,并且能夠被另外一塊 Survivor(S0) 區域所容納,
則使用復制算法將這些仍然還存活的對象復制到另外一塊 Survivor(S1) 區域中,
3.然后清理所使用過的 Eden 以及 Survivor(S0+S1) 區域,并且將這些對象的年齡設置為1
4.以后對象在 Survivor(S1) 區每熬過一次 Minor GC,就將對象的年齡 + 1,
5.當對象的年齡達到某個值時 ( 默認是15歲,-XX:MaxTenuringThreshold 來設定 ),
這些對象就會成為老年代,對于一些較大的對象 (即需要分配一塊較大的連續內存空間),
則是直接進入到老年代。
老年代:(Old Memory)
標記-清除算法
永久代: (Perm) 這jdk8后被移除修正為 <元空間>
方法區
永久代與元空間的區別:
永久代是和堆相聯的一塊物理內存
元空間是和堆內存不相關的一塊獨立的內存空間
3.垃圾回收名詞分類
Partial GC 收集java堆部分垃圾,是區別于完整收集而定義的,可以細分
Minor GC 新生代收集 (次要的)
Major GC 老年代收集 (主要的)
Mixed GC 混合收集 (GI收集器才會有這種行為)
Full GC : 收集整個java堆和方法區的垃圾 (發生在老年代的垃圾收集動作)
4.垃圾回收算法
標記-清除
標記-復制
標記-整理