CMS收集器和G1收集器对比差异?

CMS

CMS:以牺牲吞吐量为代价来获得最短回收停顿时间的垃圾回收器。对于要求服务器响应速度的应用上,这种垃圾回收器非常适合。在启动 JVM 的参数加上“-XX:+UseConcMarkSweepGC”来指定使用 CMS 垃圾回收器。基于并发“标记清理”实现

CMS收集器采用增量更新算法实现

过程:

1、初始标记:独占PUC,仅标记GCroots能直接关联的对象

2、并发标记:可以和用户线程并行执行,标记所有可达对象

3、重新标记:独占CPU(STW),对并发标记阶段用户线程运行产生的垃圾对象进行标记修正

4、并发清理:可以和用户线程并行执行,清理垃圾
在这里插入图片描述
优点:

并发收集,低停顿

缺点:

1、对CPU非常敏感:在并发阶段虽然不会导致用户线程停顿,但是会因为占用了一部分线程使应用程序变慢

2、无法处理浮动垃圾:在最后一步并发清理过程中,用户线程执行也会产生垃圾,但是这部分垃圾是在标记之后,所以只有等到下一次gc的时候清理掉,这部分垃圾叫浮动垃圾

3、CMS使用“标记-清除”法会产生大量的空间碎片,当碎片过多,将会给大对象空间的分配带来很大的麻烦,往往会出现老年代还有很大的空间但无法找到足够大的连续空间来分配当前对象,不得不提前触发一次FullGC,为了解决这个问题CMS提供了一个开关参数,用于在CMS顶不住,要进行FullGC时开启内存碎片的合并整理过程,但是内存整理的过程是无法并发的,空间碎片没有了但是停顿时间变长了

CMS 出现FullGC的原因:

1、年轻带晋升到老年带没有足够的连续空间,很有可能是内存碎片导致的

2、在并发过程中JVM觉得在并发过程结束之前堆就会满,需要提前触发FullGC

Garbage First(G1)

G1:是一款面向服务端应用的垃圾收集器

G1 收集器则是通过原始快照(SATB)算法来实现的
特点:
1、并行于并发
2、分代收集
3、空间整合
4、可预测的停顿
改变:

  • 它将整个Java堆划分为多个大小相等的独立区域(Region)

  • 虽然还保留了新生代和老年代的概念,但新生代和老年代不再是物理隔离的了它们都是一部分Region(不需要连续)的集合。

  • 为了避免全堆扫描,G1使用了RememberedSet来管理相关的对象引用信息。当进行内存回收时,在GC根节点的枚举范围中加入Remembered Set即可保证不对全堆扫描也不会有遗漏了。

过程:
1、初始标记(Initial Making)
仅仅只是标记一下GC Roots能直接关联到的对象,并且修改TAMS 指针的值,让下一阶段用户线程并发运行时,能正确地在可用的Region中分配新对象。这个阶段需要 停顿线程,但耗时很短,而且是借用进行Minor GC的时候同步完成的,所以G1收集器在这个阶段实际 并没有额外的停顿。
2、并发标记(Concurrent Marking)
从GC Root开始对堆中对象进行可达性分析,递归扫描整个堆 里的对象图,找出要回收的对象,这阶段耗时较长,但可与用户程序并发执行。当对象图扫描完成以后,还要重新处理SATB记录下的在并发时有引用变动的对象。
3、最终标记(Final Marking)
对用户线程做另一个短暂的暂停,用于处理并发阶段结束后仍遗留 下来的最后那少量的SATB记录。
4、筛选回收(Live Data Counting and Evacuation)
负责更新Region的统计数据,对各个Region的回 收价值和成本进行排序,根据用户所期望的停顿时间来制定回收计划,可以自由选择任意多个Region 构成回收集,然后把决定回收的那一部分Region的存活对象复制到空的Region中,再清理掉整个旧 Region的全部空间。这里的操作涉及存活对象的移动,是必须暂停用户线程,由多条收集器线程并行 完成的。
在这里插入图片描述
G1不是仅仅面向低延迟,停顿用户线程能够最大幅度提高垃圾收集效率,为了保证吞吐量所以才选择了完全暂停用户线程的实现方案

对比:

  • G1 GC 这是一种兼顾吞吐量和停顿时间的 GC 实现,是 Oracle JDK 9 以后的默认 GC 选项。G1可以直观的设定停顿时间的目标,相比于 CMS GC,G1 未必能做到 CMS 在最好情况下的延时停顿,但是最差情况要好很多。
  • G1 GC 仍然存在着年代的概念,但是其内存结构并不是简单的条带式划分,而是类似棋盘的 一个个 region。Region之间是复制算法,但整体上实际可看作是标记 - 整理(Mark- Compact)算法,可以有效地避免内存碎片,尤其是当 Java堆非常大的时候,G1 的优势更 加明显。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: CMS收集器G1收集器都是Java虚拟机的垃圾收集器,用于对Java程序中产生的垃圾进行回收。它们都有各自的优缺点,并且适用于不同的场景。 CMS收集器(Concurrent Mark Sweep Garbage Collector)是一种基于标记清除算法的并发收集器。它的特点是在垃圾回收时,尽量减少应用线程的停顿时间,提高系统的响应速度。CMS收集器主要分为以下几步: 1. 初始标记:标记出GC Roots能直接关联到的对象,并且暂停所有应用线程。 2. 并发标记:标记出所有GC Roots能间接关联到的对象。 3. 重新标记:标记出在并发标记阶段中被修改的对象,并且暂停所有应用线程。 4. 并发清除:清除掉所有没有被标记的对象,并且不需要暂停应用线程。 CMS收集器的优点是能够最大程度地减少应用线程的停顿时间,但是它也有一些缺点,比如它会产生大量的内存碎片,这会影响到大对象的分配效率。 G1收集器(Garbage First Garbage Collector)是一种基于分代收集算法的垃圾收集器。它的特点是能够在不停顿应用线程的情况下,高效地回收大量的垃圾。G1收集器主要分为以下几步: 1. 初始标记:标记出GC Roots能直接关联到的对象,并且暂停所有应用线程。 2. 并发标记:标记出所有GC Roots能间接关联到的对象。 3. 最终标记:标记出在并发标记阶段中被修改的对象,并且暂停所有应用线程。 4. 筛选回收:根据垃圾回收的目标,将对象分为老生代和新生代,并且对老生代进行回收。 G1收集器的优点是能够高效地回收大量的垃圾,并且不会产生大量的内存碎片。但是它也有一些缺点,比如它的性能在处理大对象时可能会受到影响。 综上所述,CMS收集器适用于需要最大程度地减少应用线程的停顿时间的场景,而G1收集器适用于需要高效地回收大量的垃圾的场景。 ### 回答2: CMS收集器G1收集器Java虚拟机中常用的两种垃圾回收器。作为Java领域的专家,我可以为您完成以下任务: 首先,我会为您介绍CMS收集器CMS(Concurrent Mark Sweep)收集器Java虚拟机中一种以获取最短回收停顿时间为目标的垃圾收集器。它采用了并发的方式进行垃圾收集,可以与用户线程同时工作,减少垃圾回收对应用程序的影响。CMS收集器主要有四个阶段:初始标记、并发标记、重新标记和并发清除。它适用于对响应时间要求较高的应用场景,但存在可用内存空间碎片化的问题,可能导致内存回收效率下降。 其次,我会为您介绍G1(Garbage First)收集器G1收集器Java虚拟机中一种面向服务端应用的垃圾收集器。它以获取更平稳的停顿时间为目标,能够对大堆内存进行高效回收。G1收集器将堆划分为若干个大小相等的区域,并根据垃圾分布情况优先回收垃圾最多的区域(garbage first原则),从而缩短回收停顿时间。G1收集器采用了分代收集和并发处理的技术,能够充分利用多核处理器,提升回收效率。它适用于对可靠性和低延迟有较高要求的应用场景。 综上所述,CMS收集器G1收集器Java虚拟机中常用的两种垃圾回收器。CMS收集器以最短回收停顿时间为目标,采用并发方式进行垃圾收集,适用于对响应时间要求较高的应用场景;而G1收集器以平稳停顿时间为目标,采用分代和并发处理技术,适用于对可靠性和低延迟有较高要求的应用场景。根据具体的应用需求和性能指标,可以选择适合的垃圾收集器来优化应用程序的性能和资源利用。 ### 回答3: CMS收集器(Concurrent Mark Sweep)和G1收集器(Garbage First)都是Java虚拟机的垃圾回收器。 CMS收集器是一种以“并发”和“低停顿”为目标的垃圾回收器。它的特点是在垃圾回收过程中,可以与用户线程并发执行。这意味着它可以在垃圾回收的同时,让应用程序继续运行,减少了停顿时间,提高了应用程序的响应速度。CMS收集器主要用于对响应时间要求较高的应用,比如Web服务端应用。 G1收集器Java虚拟机在JDK 7版本中引入的一种垃圾回收器,也是目前JDK 8默认的垃圾回收器。G1收集器是一种以“低停顿”和“高吞吐量”为目标的垃圾回收器。它通过将堆内存划分成多个大小相等的区域(Region)来管理对象,能够实现部分区域的并发垃圾回收。G1收集器采用导致停顿时间更可控的方式进行垃圾回收,可以通过设置期望的停顿时间目标来优化垃圾回收器的性能。G1收集器主要用于大内存应用,如需要处理几十GB到几百GB以上内存的应用。 相比而言,CMS收集器在垃圾回收时和用户线程并发执行,对停顿时间的控制能力更强。但是它存在着碎片问题,因为它无法进行整理内存,可能导致应用程序出现频繁的Full GC。而G1收集器通过使用Region来管理内存,可以避免碎片问题,同时还能控制停顿时间,但它在吞吐量方面不如CMS收集器。 总的来说,对于响应时间要求较高的应用,可以选择CMS收集器。对于大内存应用,可以选择G1收集器。当然,对于不同的应用场景,还需要根据具体情况进行性能测试和调优才能选取最适合的垃圾回收器。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值