1. 分类总览
2. 简述
1). 新生代收集器
a. Serial:单线程收集器,垃圾清理会导致其他全部线程停顿(Stop The World)(复制算法);
b. ParNew: Serial多线程版本(多CPU环境中效果优于Serial)(复制算法);
c. Parallel Scanvenge:并行多线程收集器,可以自由最大停顿时间和吞吐量大小。GC停顿时间可以通过牺牲吞吐量和新生代空间来换取(复制算法);
2). 老年代收集器
a. Series Old: Series老年代版本,单线程(“标记-整理”算法,);
b. Parallel Old: Parallel Scavenge的老年底版本,二者可以搭配使用,多线程(“标记-整理”算法);
c. CMS(Concurrent Mask Sweep):重点在响应速度("标记-清除"算法)
分为初始标记、并发标记、重新标记、并发清除四个过程。
初始标记会停顿时间很短;重新标记修正并发标记过程中的变动数据,停顿时间比初始标记略长;
并发标记、并发清除时间较长,但是可以并发运行其他工作线程。
缺点:
对CPU资源敏感
无法清理浮动垃圾(垃圾清理的时候产生的垃圾无法清除,只能等待下次清除)
使用标记-清除算法会导致大量的内存碎片
3). “新生”+“老年”
G1收集器
特点:
a. 并行并发
b. 分代收集
c. 空间整理
d. 可预测的停顿
参考《深入理解Java虚拟机》周志明 3.3
3. 默认垃圾回收器
参考:https://blog.youkuaiyun.com/shi2huang/article/details/80085193