JDK 8 到底默认用的是哪款 GC 收集器?
为啥是 JDK8?不是 9 也不是 10?因为 JDK8 还是市场占有率最高的,所以针对这个版本我做了深入的探索。
《深入理解 Java 虚拟机》第三版第 128 页中提到 JDK 9 之前,Server 默认使用 Parallel Scavenge + Serial Old(PS MarkSweep),那么真的是这样的吗? 我带着这个疑问做了如下验证
- 直接使用命令查看一下当前 JVM 默认参数
java -XX:+PrintCommandLineFlags -version
输入内容如下
-XX:InitialHeapSize=268435456
-XX:MaxHeapSize=4294967296
-XX:+PrintCommandLineFlags
-XX:+UseCompressedClassPointers
-XX:+UseCompressedOops
-XX:+UseParallelGC
java version "1.8.0_162"
Java(TM) SE Runtime Environment (build 1.8.0_162-b12)
Java HotSpot(TM) 64-Bit Server VM (build 25.162-b12, mixed mode)
第 6 行我们可以看到使用的是 -XX:+UseParallelGC 按照书中或者是网上的文章发现,设置这个参数以后默认就是如下两个组合,新生代用 Parallel Scavenge 老年代用 Serial Old
Parallel Scavenge + Serial Old
那么这里再详细科普一下,下面是每个参数对应的回收器的类型
参数回收器-XX:-UseSerialGCSerial + Serial Old-XX:-UseParNewGCParNew + Serial Old-XX:-UseParallelGCParallel Scavenge + Serial Old-XX:-UseParallelOld