JVM 内存模型和垃圾回收(五): Garbage-First

来源:互联网 发布:java面试线程问题 编辑:程序博客网 时间:2024/05/22 12:34

JVM 内存模型和垃圾回收(五): Garbage-First

G1回收是一个服务端的回收方式,适用于多个cpu和内存比较大的服务器使用。

在6GB之下的内存下,CMS性能会更好,在6GB之上,G1的性能更好。并且在官方宣称G1是用来未来替换CMS的。

和CMS不同的一点是:

  • G1是将内存分为相等的区域,然后由区域组成逻辑上的Young, Old。
  • G1是一个可以compact的垃圾回收器

着重说一下对old generation的操作:

  1. 初始化标记(STW)
    在此阶段,G1 GC 对根进行标记。该阶段与常规的年轻代垃圾回收密切相关。
  2. 根region扫描
    在初始标记的存活区扫描对老年代的引用,并标记被引用的对象。该阶段与应用程序(非 STW)同时运行,并且只有完成该阶段后,才能开始下一次 STW 年轻代垃圾回收。
  3. 并发标记阶段
    G1 GC 在整个堆中查找可访问的(存活的)对象。该阶段与应用程序同时运行,可以被 STW 年轻代垃圾回收中断。
  4. 重新标记阶段
    该阶段是 STW 回收,帮助完成标记周期。清空 SATB (snapshot-at-the-beginning)区,跟踪未被访问的存活对象,并执行引用处理。
  5. 清理阶段
    执行统计和 RSet 清理STW 操作。G1会识别完全空闲的区域和可供进行混合垃圾回收的区域。清理阶段在将空白区域重置并返回到空闲列表时,该阶段为部分并发
  6. 拷贝
    分散或者拷贝存活的对象到那些没有使用的region。

过程和CMS差不多,主要的特点是:

将内存分为region,然后这样就会有更多的选择。只是新增了一种模式, mixed gc。以前可能就是ygc, full gc.现在G1的目标就是尽可能减少full gc,可能通过mixed gc来释放空间。

原创粉丝点击