垃圾收集器类型
-
Serial 收集器
单线程收集器,工作时必须停止其他所有线程,简单高效,适合Client模式下的虚拟机
-
Serial Old 收集器
Serial 收集器的老年代版本,同样也是单线程收集器
-
ParNew 收集器
Serial收集器的多线程版本,适合Server模式下的虚拟机。新生代采用
复制算法
,老年代采用标记-整理算法
-
Parallel Scavenge 收集器
使用复制算法的多线程收集器,关注吞吐量,适合考虑吞吐量和CPU的场景。新生代采用
复制算法
,老年代采用标记-整理算法
-
Parallel Old 收集器
Parallel Scavenge 收集器的老年代版本,适合考虑吞吐量和CPU的场景
-
CMS 收集器 (Concurrent Mark Sweep)
以最短回收停顿时间为目标的收集器,注重用户体验。采用
标记-清除算法
-
G1 收集器 (Garbage-First)
面向服务器的垃圾收集器,主要针对配备多核处理器及大容量内存的机器。以极高概率满足 GC 停顿时间要求的同时,还具备高吞吐量性能特征,整体看采用
标记-整理算法
,局部看采用复制算法
查看默认垃圾回收收集器类型
java -XX:+PrintCommandLineFlags -version
C:\Users\dkangel>java -XX:+PrintCommandLineFlags -version
-XX:InitialHeapSize=265388416 -XX:MaxHeapSize=4246214656 -XX:+PrintCommandLineFlags -XX:+UseCompressedClassPointers -XX:+UseCompressedOops -XX:-UseLargePagesIndividualAllocation -XX:+UseParallelGC
java version "1.8.0_191"
Java(TM) SE Runtime Environment (build 1.8.0_191-b12)
Java HotSpot(TM) 64-Bit Server VM (build 25.191-b12, mixed mode)
可以看出jdk采用默认收集器采用ParallelGC
打印的GC日志
java -XX:+PrintGCDetails
C:\Users\dkangel>java -XX:+PrintGCDetails -version
java version "1.8.0_191"
Java(TM) SE Runtime Environment (build 1.8.0_191-b12)
Java HotSpot(TM) 64-Bit Server VM (build 25.191-b12, mixed mode)
Heap
PSYoungGen total 75776K, used 2601K [0x000000076ba00000, 0x0000000770e80000, 0x00000007c0000000)
eden space 65024K, 4% used [0x000000076ba00000,0x000000076bc8a558,0x000000076f980000)
from space 10752K, 0% used [0x0000000770400000,0x0000000770400000,0x0000000770e80000)
to space 10752K, 0% used [0x000000076f980000,0x000000076f980000,0x0000000770400000)
ParOldGen total 173568K, used 0K [0x00000006c2e00000, 0x00000006cd780000, 0x000000076ba00000)
object space 173568K, 0% used [0x00000006c2e00000,0x00000006c2e00000,0x00000006cd780000)
Metaspace used 2291K, capacity 4480K, committed 4480K, reserved 1056768K
class space used 254K, capacity 384K, committed 384K, reserved 1048576K
详细看出新生代采用PS(Parallel Scavenge)
收集器,老年代采用 ParOld(Parallel Old)
收集器
结论
jdk1.8 默认垃圾收集器:新生代采用
Parallel Scavenge
,老年代采用Parallel Old