Java8中GC收集器详解

新生代默认垃圾回收算法:标记复制          

老年代默认回收算法:标记整理

Minor GC和Full GC

Minor GC只针对新生代,触发条件:当Eden区满时,触发Minor GC。

Full GC包含新生代和老年代,触发条件:

(1)调用System.gc时,系统建议执行Full GC,但是不必然执行

(2)老年代空间不足

(3)方法区空间不足

(4)通过Minor GC后进入老年代的平均大小大于老年代的可用内存

(5)由Eden区、From Space区向To Space区复制时,对象大小大于To Space可用内存,则把该对象转存到老年代,且老年代的可用内存小于该对象大小。

接下里我们需要查看Java8默认的GC收集器:

查看Java8默认的GC收集器

java -XX:+PrintCommandLineFlags -version

结果如下图:

-XX:+UseParallelGC实际上是Parallel Scavenge (新生代)+ Parallel Old(老年代)

查看GC详情

java -XX:+PrintGCDetails -version

结果如下 

 下面我们来讲一下GC收集器

新生代:

1.serial收集器

单线程,工作时必须暂停其他工作线程。多用于client机器上,使用复制算法
2、ParNew收集器

serial收集器的多线程版本,server模式下虚拟机首选的新生代收集器。复制算法

3、Parallel Scavenge收集器

复制算法,可控制吞吐量的收集器。吞吐量即有效运行时间。

老年代:

4、Serial Old收集器

serial的老年代版本,使用整理算法。

5、Parallel Old收集器
第三种收集器的老年代版本,多线程,标记整理
6、CMS收集器
目标是最短回收停顿时间。

7、G1收集器

基本思想是化整为零,将堆分为多个Region,优先收集回收价值最大的Region

垃圾回收器的选择策略:

1、单CPU或者小内存,单机程序 — -XX:+UseSerialGC

2、多CPU,需要大吞吐量,如后台计算型应用

-XX:+UseParallelGC + -XX:+UseParallelOldGC

3、多CPU,追求低停顿时间,快速响应如互联网应用

-XX:+UseParNewGC + -XX:+UseConcMarkSweepGC


版权声明:本文为weixin_42324471原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
THE END
< <上一篇
下一篇>>