CMS收集器
CMS核心理念:减少用户线程stw阻塞等待时间
CMS特点:串行和并行收集器都会暂停所有的用户线程 ,但CMS处理空间较大的堆内存,而且还可以减少stw暂停用户线程时间。
优点:减少用户线程stw阻塞等待时间;用户线程和gc线程同时运行。
缺点:导致内存空间碎片化;多核消耗cpu资源;会产生浮动垃圾;无法存放大对象时会触发fullgc。
1、为什么串行收集器和并行收集器对用户线程的暂停时间都会很长?
答:根据GCRoot查找到整个引用链,只要是在GCRoot关联的引用链下,都标记可用。如果引用链过长,GC标记及清理垃圾非常消耗时间,会导致用户线程暂停时间比较长。
2、CMS底层原理
① 初始标记(CMS initial mark)。标记GCRoot能够直接关联到的对象,可以是1个或n个。短暂的stw,过程非常快。
② 并发标记(CMS concurrent mark)。用户线程和gc标记线程同时运行,gc线程根据初始标记得到直接引用对象,继续标记引用链中的对象。
③ 重新标记(CMS remark)。初始标记之后的并发标记过程中,gc线程和用户线程同时运行,有可能会发生引用改变,所以需要重新修正。stw的时间比初始标记时间长,比并发标记时间短。
④ 并发清除(CMS concurrent sweep)。用户线程和gc同时运行,gc同时运行清除堆内存垃圾,用户线程可以正