垃圾收集器

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

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章