低延迟的CMS(Concurrent-Mark-Sweep)垃圾回收器

CMS垃圾回收器

JDK1.5,HotSpot推出了一款在强交互应用中几乎可以认为有划时代意义的垃圾收集器: CMS(Concurrent-Mark-Sweep)。

特点:

  • 真正意义上的并发收集,垃圾回收线程能够与用户线程同时工作!
  • 垃圾收集时,用户线程停顿时间(STW)很短。
  • 老年代垃圾回收器,采用标记-清除算法

工作原理

清理过程:

初始标记(STW)-> 并发标记(同用户线程一起)->重新标记(STW)->并发清理(同用户线程一起)->重置线程(同用户线程一起)

图解:

在这里插入图片描述

缺点:

由于采用的是标记-清理算法,垃圾回收后内存中会存在一些内存碎片,无法使用指针碰撞的方式分配内存,只能选择空闲列表执行内存分配。

参数设置

  1. -XX:+UseConcMarkSweepGC,手动指定使用CMS收集器
  2. -XX:CMSInitiatingOccupanyFraction,设置堆内存使用率的阈值,到达该阈值,就会进行回收。
  3. -XX:+UseCMSCompactAtFullCollection,指定执行完full GC后对内存空间进行压缩整理。
  4. -XX:CMSFullGCsBeforeCompaction,设置执行多少次GC后进行内存的压缩整理。
  5. -XX:ParallelCMSThreads,设置CMS的线程数量。默认是(ParallelGCThreads+3)/4。 ParallelGCThreads是年轻代并行收集器的线程数。

JDK后续版本CMS变化情况

  • JDK9中,CMS标记为Deprecate了
  • JDK14,删除CMS垃圾回收器
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值