参考资料:深入理解Java虚拟机:JVM高级特性与最佳实践(第3版)周志明
CMS收集器(Concurrent Mark Sweep)是一种以获取最短回收停顿时间为目标的收集器。低并发收集、低停顿。
-
CMS收集器是基于标记—清除算法实现的,它的运作过程分为四个步骤:
-
初始标记:标记GC Roots能直接关联的对象;该操作很快,需要暂停用户线程。
-
并发标记:从GC Roots直接关联对象开始遍历整个对象图的过程。过程耗时长,但不会暂停用户线程,并且可以与垃圾收集线程并发运行。
-
重新标记:重新标记则是为了修正并发标记期间,用户程序继续运作,导致标记变动的那一部分对象的标记记录。需要暂停用户线程,比初始标记长比并发标记短。
-
并发清除:清理标记阶段判断已经死亡的对象,由于不需要移动存活对象,所以该过程也是与用户线程并发的。
CMS有以下三个明显缺点:
-
CUP性能消耗:多开线程,使得CPU消耗增加。
-
浮动垃圾(Floating Garbage):由于GC线程和用户线程并发,在GC线程运行过程中产生的垃圾就叫浮动垃圾。这部分垃圾无法在当次收集中处理掉它,只好留到下一次垃圾收集中清理。
-
内存碎片:CMS基于标记-清除算法,会产生大量的内存碎片,内存碎片过多会导致大对象的分配出现问题,严重的话会出现OOM。