一、G1特点
1.同时注重吞吐量和低延时 ,默认暂停目标 200ms
2.超大堆内存,将堆划分为多个大小相等的Region(区域)(值:1、2、4、8)
每个区域都可以作为伊甸园幸村区老年代
3.整体上是标记+整理算法,两个区域之间是复制算法
二、执行过程
Young Collection
会stw
新创建的对象放到伊甸园,当放满,触发新生代的垃圾回收
新生代内存紧张,把伊甸园中存活的对象复制到幸存区
幸存区内存比较多了 对象存活年龄超过阈值,又会触发新生代垃圾回收
一部分晋升到老年代
不够年龄的复制到另一个幸存区
Young Collection+CM
新生代垃圾回收+并发标记
在YongGC时候会进行GCRoot的初始标记(不会STW)
老年代占用堆空间比例达到阈值的时候(默认45%),进行并发标记(不会STW)
Mixed Collection
最终标记 (STW)
拷贝存活(STW)
混合收集
对伊甸园 幸存区 老年代 全面垃圾回收
为了达到暂停时间短的目标,对于老年代的存活拷贝(G1是分区域的,其中很多区域都是老年代)不会全部回收,会回收一些释放空间最多的老年代
三、
CMS与G1一样:
垃圾回收的速度跟不上新产生的垃圾,并发就失败了,就会退化为串行的收集,这时候会FullGC
Young Collection跨代引用
新生代垃圾回收 先可达性分析(先找gc roots,再沿着链找存活对象)找存活对象
老年代引用新生代问题
根对象一部分来自老年代,老年代的存活对象很多,如果遍历整个老年代去找gcroots,显然效率低。
采用crad技术(卡表)将老年代分为很多512k的区域
如果一个card中有对象引用了新生代中的对象,就把card标记为脏card
这样做gcroots遍历的时候就不用找整个老年代了,只需要关注脏card就可以了
新生代中有个Remembered Set 记录老年代中的脏card
引用变更的时候,通过写屏障更新脏card,这是异步操作,不会马上更新,先将更新的指令放到一个脏card的队列之中。后续让一个线程完成脏card的更新操作