JVM之垃圾回收器

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版》——周志明 

 

 


 

猜你喜欢

转载自youyu4.iteye.com/blog/2354126