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的探索与实践 - 美团技术团队
热门推荐
银行账户信息修改所需证件全攻略
期货套利的操作方法有哪些?这些方法的收益情况如何?
从3D扫描到CAD模型:逆向工程实战指南
如何安全握刀?
为什么猫猫喜欢跟着人(探秘宠物猫的行为心理)
这样备份Windows 11,不用收费软件,全是系统自带的免费工具
飞蚊症是什么病?眼前出现飞蚊症的原因及症状解析
这5条骑行线路,藏着山西最美的秋天!
从法律层面谈强制参加基本医疗保险的四大原因
氧化锌软膏使用指南:从成分到副作用的全面解析
10条路线带你走进贵州“中国传统村落”
蔗糖和红糖的区别是什么
倪海厦解读《黄帝内经》视频版合集(1-90集 共90集)
成都老字号美食地图:探寻成都味道的历史传承
《诗经·国风·周南·桃夭》赏析
药物化疗和输液化疗区别
35度4是正常体温吗
小孩眼睛突然红了怎么回事
常用的元器件装配质量控制和检验方法
龙之谷世界0氪最强职业排名 龙之谷世界0氪选什么职业
景区如何挑选开店项目?精准布局提升游客消费体验的实用指南
麦肯锡:2024年职场女性报告
PGIS用的是什么数据库
沟通的七条核心原则
滕王阁:“ 落霞与孤骜齐飞,秋水共长天一色”
职场逆袭:提升临场应变力
火字旁一个橘子的橘
爆火!数据分析看“黑猴儿”:以《黑神话:悟空》为例,数据分析在游戏行业的力量!
苏轼超然物外的一首春景词,最后三句堪称绝唱,激励了世人上千年
1961年,中央军委组建空15军,为何驻防武汉军区?军部选址有讲究