一、CMS是什么
C表示并发,MS表示标记清除,全称 Concurrent Mark Sweep。是一款强交互低延迟的垃圾收集器,作用于老年代,与ParNew或者Serial收集器配合使用。
二、CMS执行过程
初始标记:STW,标记与GC Roots直接关联到的对象,关联的对象比较少,STW时间短。
并发标记:从GC Roots关联的对象遍历整个对象图,针对存活的对象进行标记,耗时比较长但不需要停顿用户线程,垃圾线程和用户线程同 时进行中。
重新标记:STW,修正并发期间,用户线程继续执行而导致标记产生变动的那一部分对象的标记记录(并发标记怀疑是垃圾,重新标记进行验证确定)。
并发清除:清理删除掉标记阶段判断已死亡的对象,释放空间(没有移动对象),垃圾线程和用户线程同时进行中。
三、特点
CMS收集器不是等到老年代几乎完全填满再进行收集,达到某个阈值时就开始进行回收,要确保有足够的内存空间支持应用程序运行,因为是并发执行用户线程和回收线程,用户线程会一直在产生垃圾,如果预留的内存无法满足程序需要,就会出现垃圾回收失败,启动后备方案:serial old收集器来重新进行老年代垃圾收集,该方案回收垃圾效率低。
因为采用标记-清除算法,执行效率高,但产生碎片化,采用空闲列表执行内存分配。(可以通过参数配置进行垃圾整理)
为什么不采用标记-压缩算法是因为:压缩时候会移动存活对象,用户线程没法继续执行,除非停止用户线程。
四、优缺点
优点:并发收集、低延迟
缺点(删除原因):碎片化、占用线程数,总吞吐量降低、无法处理浮动垃圾
五、适用场景
通常用于互联网或者B/S系统的服务端,关注服务器响应速度,带来用户较好的交互体验。
*注:
1、浮动垃圾:并发标记和并发清除阶段用户线程新产生的垃圾,只能留到下次处理