JVM 内存模型和垃圾回收(五): Garbage-First
G1回收是一个服务端的回收方式,适用于多个cpu和内存比较大的服务器使用。
在6GB之下的内存下,CMS性能会更好,在6GB之上,G1的性能更好。并且在官方宣称G1是用来未来替换CMS的。
和CMS不同的一点是:
- G1是将内存分为相等的区域,然后由区域组成逻辑上的Young, Old。
- G1是一个可以compact的垃圾回收器
着重说一下对old generation的操作:
- 初始化标记(STW)
在此阶段,G1 GC 对根进行标记。该阶段与常规的年轻代垃圾回收密切相关。 - 根region扫描
在初始标记的存活区扫描对老年代的引用,并标记被引用的对象。该阶段与应用程序(非 STW)同时运行,并且只有完成该阶段后,才能开始下一次 STW 年轻代垃圾回收。 - 并发标记阶段
G1 GC 在整个堆中查找可访问的(存活的)对象。该阶段与应用程序同时运行,可以被 STW 年轻代垃圾回收中断。 - 重新标记阶段
该阶段是 STW 回收,帮助完成标记周期。清空 SATB (snapshot-at-the-beginning)区,跟踪未被访问的存活对象,并执行引用处理。 - 清理阶段
执行统计和 RSet 清理STW 操作。G1会识别完全空闲的区域和可供进行混合垃圾回收的区域。清理阶段在将空白区域重置并返回到空闲列表时,该阶段为部分并发 - 拷贝
分散或者拷贝存活的对象到那些没有使用的region。
过程和CMS差不多,主要的特点是:
将内存分为region,然后这样就会有更多的选择。只是新增了一种模式, mixed gc。以前可能就是ygc, full gc.现在G1的目标就是尽可能减少full gc,可能通过mixed gc来释放空间。