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