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的操作:
- 初始化标记(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来释放空间。
阅读全文
0 0
- JVM 内存模型和垃圾回收(五): Garbage-First
- Java(JVM)内存模型,垃圾回收
- JVM 内存模型和垃圾回收(二): 串行垃圾回收器
- JVM 内存模型和垃圾回收(三): 并行回收器
- JVM 内存模型和垃圾回收(四): 并发回收(Concurrent Mark-Sweep Collector)
- 浅析JVM 第二篇(JVM内存模型和垃圾回收)
- JVM内存模型&内存溢出&垃圾回收
- JVM的内存模型和垃圾回收机制
- jvm垃圾回收——垃圾优先Garbage-First收集器
- JVM内存模型以及垃圾回收
- JVM内存模型以及垃圾回收
- JVM内存模型以及垃圾回收
- JVM内存模型以及垃圾回收
- JVM内存模型以及垃圾回收
- JVM内存模型以及垃圾回收
- JVM内存模型以及垃圾回收
- JVM内存模型以及垃圾回收
- JVM内存模型及垃圾回收机制
- libevent多线程
- React.js初探-如何将一个普通button改造成类React组件
- html选择器
- linux使用随用随记
- unity 游戏体围绕x,y,z轴进行转动
- JVM 内存模型和垃圾回收(五): Garbage-First
- 推荐算法之Jaccard相似度与Consine相似度
- 性能测试的小思考
- Hbase WAL 机制记录
- Cordova进阶:多方法插件
- Latex参考文献的引用
- Java 的异常
- 编译错误和运行错误;
- PostgreSQL数据类型