CMS只针对老年代,使用的是标记清除算法,会产生内存碎片,最小等待时间优先的垃圾收集器
CMS回收垃圾的4个阶段
- 初始标记:stop the world状态,所有线程全部停止
- 并发标记:不会STW,对所有对象进行追踪,最耗时
- 重新标记:修正并发标记期间 因用户程序继续运作 而导致标记产生变动的那一部分对象的标记记录
- 并发清理:并发执行,不会对系统造成很大的影响
优点:并发收集、低停顿
缺点:1. 采用标记清除算法会造成内存碎片过多
2. 并发标记和并发清理都是并发执行的,会消耗额外的CPU资源
G1将Java内存拆分成多个region(独立区域),打破了分代模型,这样子就不需要在全堆范围内进行收集
JDK9默认使用的是G1垃圾回收器,使用的是标记整理算法,可预测的停顿
G1回收垃圾的4个阶段:
- 初始标记:标记GC Roots 可以直接关联的对象,该阶段需要线程停顿但是耗时短
- 并发标记:寻找存活的对象,可以与其他程序并发执行,耗时较长
- 最终标记:修正并发标记期间 因用户程序继续运作 而导致标记产生变动的那一部分对象的标记记录
- 筛选回收:对每个Region的回收成本进行排序,按照用户自定义的回收时间来制定回收计划
优点:垃圾回收时间可控,可预测的停顿,可以选择一组合适的region作为回收目标,实时收集、标记整理算法不会产生内存碎片
总结:
CMS:最小等待时间有限的垃圾回收器
G1:可控垃圾回收时间的垃圾回收器