JVM垃圾收集器之CMS垃圾收集器和G1垃圾收集器

CMS垃圾收集器

CMS垃圾收集器

CMS GC的英文名为:"Mostly Concurrent Mark and Sweep Garbage Collector" (最大-并发-标记-清除-垃圾收集器)。

作用范围: 老年代

算法: 并发标记清除算法。

启用参数:-XX:+UseConMarkSweepGC默认回收线程数:(处理器核心数量 + 3)/4

Java9之后使用CMS垃圾收集器后,默认年轻代就为ParNew收集器,并且不可更改,同时JDK9之后被标记为不推荐使用,JDK14就被删除了。

设计目标/优点:避免在老年代垃圾收集时出现长时间的卡顿,主要通过两种手段来达成此目标:

第一,不对老年代进行整理,而是使用空闲列表(free-list)来管理内存空间的回收

第二,在mark-and-sweep(标记-清除)阶段的大部分工作和应用线程一起并发执行。

适用场景:

GC过程短暂,低延迟,适合对延迟要求较高的系统

如果服务器是多核CPU,并且主要调优目标是降低GC停顿导致的系统延迟,那么使用CMS是个很明智的选择。通过减少每一次GC停顿的时间,很多时候会直接改善用户体验。因为多数情况下有部分CPU资源被垃圾回收器线程消耗,所以在CPU资源受限的情况下,CMS GC会比并行GC的吞吐量差一些(对于绝大部分系统,这个吞吐和延迟的差别应该都不明显)

在实际情况中,进行老年代的并发回收时,可能会伴随多次年轻代的minor GC。在这种情况下full GC的日志中就会掺杂着多次minor GC事件

CMS GC的几个大阶段

1、初始标记(CMS initial mark)

2、并发标记(CMS concurrent mark)

3、重新标记(CMS remark)

4、并发清除(CMS concurrent sweep)

其中:1、3会STW

G1收集器

G1待更新

相关推荐
Hungry_Shark3 分钟前
IDEA版本控制管理之使用Gitee
java·gitee·intellij-idea
赛姐在努力.5 分钟前
《IDEA 突然“三无”?三秒找回消失的绿色启动键、主菜单和项目树!》
java·intellij-idea
未来之窗软件服务7 分钟前
幽冥大陆(二)RDIFSDK 接口文档:布草洗涤厂高效运营的技术桥梁C#—东方仙盟
开发语言·c#·rdif·仙盟创梦ide·东方仙盟
猎板PCB黄浩13 分钟前
从废料到碳减排:猎板 PCB 埋容埋阻的绿色制造革命,如何实现环保与性能双赢
java·服务器·制造
ZzzK,13 分钟前
JAVA虚拟机(JVM)
java·linux·jvm
西红柿维生素19 分钟前
JVM相关总结
java·jvm·算法
小冯记录编程22 分钟前
C++指针陷阱:高效背后的致命危险
开发语言·c++·visual studio
1uther43 分钟前
Unity核心概念⑨:Screen
开发语言·游戏·unity·c#·游戏引擎
C_Liu_1 小时前
C++:类和对象(下)
开发语言·c++
coderxiaohan1 小时前
【C++】类和对象1
java·开发语言·c++