JVM 几种垃圾回收器对比
创作时间:
作者:
@小白创作中心
JVM 几种垃圾回收器对比
引用
CSDN
1.
https://blog.csdn.net/chen1030416518/article/details/140374318
JVM中的垃圾回收器是Java虚拟机的重要组成部分,负责自动管理内存,释放不再使用的对象所占用的内存空间。不同的垃圾回收器在回收区域、回收算法、线程模式等方面存在差异,适用于不同的应用场景。本文将详细介绍几种常见的JVM垃圾回收器及其工作原理。
垃圾收集器 | 回收区域 | 回收算法 | 单/多线程 | 备注 |
|---|---|---|---|---|
Serial | 新生代 | 标记-复制 | 单线程 | |
Serial Old | 老年代 | 标记-整理 | 单线程 | Serial 的老年代版本;与 Parallel Scavenge 收集器搭配使用(jdk1.5以前);用作 CMS 收集器的后备方案 |
ParNew | 新生代 | 标记-复制 | 多线程 | Serial 的多线程版本 |
Parallel Scavenge | 新生代 | 标记-复制 | 多线程 | 其目标是达到一个可控制的吞吐量 |
Parallel Old | 老年代 | 标记-整理 | 多线程 | Parallel Scavenge 的老年代版本 |
CMS | 老年代 | 标记-清除 | 混合 | 重要、并发。(ParNew是CMS默认的新生代垃圾回收器) |
G1 | 整堆 | 标记-复制? | 混合 | 并发 |
ZGC | 整堆 | 标记-复制? | 并发 |
CMS工作过程
CMS(Concurrent Mark Sweep)收集器的工作过程分为4个步骤:
- 初始标记
- 暂停所有的其他线程,并记录下直接与 root 相连的对象,速度很快。
- 并发标记
- 同时开启 GC 和用户线程,用一个闭包结构去记录可达对象。但在这个阶段结束,这个闭包结构并不能保证包含当前所有的可达对象。因为用户线程可能会不断的更新引用域,所以 GC 线程无法保证可达性分析的实时性。所以这个算法里会跟踪记录这些发生引用更新的地方。
- 重新标记
- 重新标记阶段就是为了修正并发标记期间因为用户程序继续运行而导致标记产生变动的那一部分对象的标记记录,这个阶段的停顿时间一般会比初始标记阶段的时间稍长,远远比并发标记阶段时间短。
- 并发清除
- 开启用户线程,同时 GC 线程开始对未标记的区域做清扫。
CMS 收集器有 3大缺点:浮动垃圾,并发失败以及内存碎片。
G1工作过程
G1(Garbage-First)收集器的工作过程如下:
- 当不需要清理老年代时,只回收新生代。
- 当整堆占用达到指定阈值(初始值45%),需要回收老年代:
- 先进行一次年轻代回收过程,这个过程是Stop-The-World的。
- 恢复应用程序线程的执行。
- 开始老年代对象的标记过程。此过程是与应用程序线程并发执行的。标记过程会记录弱引用情况,还会计算出每个分段的对象存活数据(比如分段内存活对象所占的百分比)。
- Stop-The-World,然后 重新标记(Remark)。此阶段重新标记前面提到的STAB队列中的对象(例子中的C对象),还会处理弱引用。
- 回收百分之百为垃圾的内存分段。注意:不是百分之百为垃圾的内存分段并不会被处理,这些内存分段中的垃圾是在混合回收过程(Mixed GC)中被回收的。由于Humongous对象会独占整个内存分段,如果Humongous对象变为垃圾,则内存分段百分百为垃圾,所以会在第一时间被回收掉。
- 恢复应用程序线程的执行。
G1垃圾回收器的运行过程大致可划分为以下四个步骤:
- 初始标记(initial mark),标记了从GC Root开始直接关联可达的对象。STW(Stop the World)执行。
- 并发标记(concurrent marking),和用户线程并发执行,从GC Root开始对堆中对象进行可达性分析,递归扫描整个堆里的对象图,找出要回收的对象。
- 最终标记(Remark),STW,标记再并发标记过程中产生的垃圾。
- 筛选回收(Live Data Counting And Evacuation),制定回收计划,选择多个Region 构成回收集,把回收集中Region的存活对象复制到空的Region中,再清理掉整个旧 Region的全部空间。需要STW。
ZGC工作过程
ZGC(Z Garbage Collector)的工作过程与G1类似,但有以下不同:
- ZGC只有三个STW阶段:初始标记,再标记,初始转移。
- 初始标记和初始转移分别都只需要扫描所有GC Roots,其处理时间和GC Roots的数量成正比,一般情况耗时非常短。
- 再标记阶段STW时间很短,最多1ms,超过1ms则再次进入并发标记阶段。
- ZGC几乎所有暂停都只依赖于GC Roots集合大小,停顿时间不会随着堆的大小或者活跃对象的大小而增加。
- 与ZGC对比,G1的转移阶段完全STW的,且停顿时间随存活对象的大小增加而增加。
参考资料
- JVM垃圾回收详解(重点) | JavaGuide
- 肝了一周,彻底弄懂了 CMS收集器原理,这个轮子造的真值!-腾讯云开发者社区-腾讯云
- https://www.cnblogs.com/yufengzhang/p/10571081.html
- G1垃圾回收器的工作流程-阿里云开发者社区
- 新一代垃圾回收器ZGC的探索与实践 - 美团技术团队
热门推荐
SQL与NoSQL数据库的深度对比及适用场景分析
解决文件无法删除问题的有效方法与技巧总结
走进庐山风景名胜区(江西)
客厅窗户高度尺寸标准及安装注意事项
缺席判决的送达方式及其生效时间
向阳而行 一路生花 读李娟《遥远的向日葵地》
病假证明如何出具才有法律效力
我国南海的大宝藏:淡水资源可供6万人的永暑岛,究竟有多重要?
历史名人介绍-晚清名臣李鸿章
诈骗共犯与帮信罪有什么区别
与子山谷:红色IP打造乡村振兴新模式
一文带你深入学习Spring注解之@Async使用
新股上市第一天的涨跌幅限制为多少2025最新消息
宁波大学站开展“雷锋守护计划”主题活动
农村客运循环运营模式:为农村地区提供便捷交通服务的新思路
7个临床案例证明:干细胞治疗这类致死疾病有巨大潜力
又晒又热,快要“熟了”……国医大师禤国维教你日光性皮炎的养护!
预亏5-6亿,恩捷股份遭遇“利润断崖”,9万股民多少失眠?
C语言图形化编程买什么书
幽门螺杆菌四联治疗14天后仍为阳性?原因分析与应对方案
如何正确佩戴沉香和保养存放?
扁桃体手术的风险和后遗症全解析
Scratch编程入门指南:从零基础到项目开发
2025【俄罗斯收款方式】最全解析:跨境支付挑战与解决方案
电线颜色国家标准及代表字母含义
如何调整离合器高低?这种调整方法对驾驶体验有何影响?
ROS开发中激光雷达常见问题及解决方案
丝印机操作流程全攻略
怎样内部解决劳动争议
养猫家庭必读:如何安全使用清洁剂?