JVM之垃圾回收器
垃圾回收器总共分四大类
串行垃圾回收器(Serial Garbage Collector)
- Serial(年轻代):复制算法,单线程
- Serial Old(老年代):标记 - 整理算法,单线程
并行垃圾回收器(Parallel Garbage Collector)
- parallel(年轻代):复制算法,多线程
- Parallel Old(老年代):标记 - 整理算法,多线程
- ParNew(年轻代):Serial收集器的多线程版本,许多运行在Server模式下的虚拟机中首选的新生代收集器,除Serial外,只有它能与CMS收集器配合工作。
并发标记扫描垃圾回收器(CMS Garbage Collector)
- CMS(老年代):标记 - 清除算法,以最短停顿时间为目标,不过会产生内存空间碎片,回收结束后要进行一次内存压缩,可配置。
G1垃圾回收器(G1 Garbage Collector)
- G1(年轻代 + 老年代):标记 - 整理算法,可以非常精确控制停顿时间,在不牺牲吞吐量的前提下,实现低停顿垃圾回收。
七种垃圾回收器的比较
七种垃圾回收器的组合使用
调节新生代的三组参数
- 最高优先级: -XX:NewSize=1024m和-XX:MaxNewSize=1024m
- 次高优先级: -Xmn1024m (需要1.4以上,效果等同于:-XX:NewSize=-XX:MaxNewSize=1024m)
- 最低优先级: -XX:NewRatio=2 ,老年代:新生代之比
备注
- jvm选项中,-X选项是非标准的,不保证被所有VM实现支持,也可能在将来被改变;-XX选项是不稳定的,可能在将来被改变。
- 使用-XX:+PrintFlagsFinal可以查看所有开启的VM选项。
参考:
《深入理解Java虚拟机 第2版》——周志明