g1和cms区别

 

苏格拉低 2019-10-28 23:39:30 5287 收藏 2
分类专栏: 面试积累
版权
cms回收器执行步骤

1、初始标记:GC roots  可以理解为对象指向的标记

2、并发标记: GC roots Tracing  可以理解为 通过初始标记找到了要删除的对象  也就是堆中的指向对象

3、重新标记: 可以理解为重新执行了一遍 初始标记 和 并行标记  产生标记记录

4、删除标记:标记删除发进行并发删除

优点:并行执行,低停顿

缺点:

1、不停顿耗线程,耗内存,整体效率低

2、标记清除法会产生垃圾碎片 容易FGC

3、会产生浮动垃圾容易FGC

 

g1回收器:

1、初始标识:GC roots  可以理解为对象指向的标记  并且更改tame值出发并发标记

2、并发标记:GC roots Tracing  可以理解为 通过初始标记找到了要删除的对象  也就是堆中的指向对象

3、最终标记: 可以理解为重新执行了一遍 初始标记 和 并行标记  产生标记记录 将标记记录存到remember set log中,然后在合并到 remember set中,通过remember set 来管理对象的引用

4、筛选回收:通过Region区块对回收价值和成本进行排序,根据用户所希望的GC时间进行回收。

优点:

1、空间整合:g1使用Region独立区域概念,g1利用的是标记复制法,不会产生垃圾碎片

2、分代收集:g1可以自己管理新生代和老年代

3、并行于并发:g1可以通过机器的多核来并发处理 stop - The - world停顿,减少停顿时间,并且可不停顿java线程执行GC动作,可通过并发方式让GC和java程序同时执行。

4、可预测停顿:g1除了追求停顿时间,还建立了可预测停顿时间模型,能让制定的M毫秒时间片段内,消耗在垃圾回收器上的时间不超过N毫秒

最大的区别是出现了Region区块概念,可对回收价值和成本进行排序回收,根据GC期望时间回收,还出现了member set概念,

将回收对象放入其中,避免全堆扫描
————————————————
版权声明:本文为CSDN博主「苏格拉低」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/u010310183/article/details/102790573

posted on   myf008  阅读(410)  评论(0编辑  收藏  举报

编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示