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

CMS垃圾回收器

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

特点:

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

工作原理

清理过程:

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

图解:

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

缺点:

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

参数设置

  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垃圾回收器