1. GC介绍
GC就是垃圾回收器。因为内存空间是有限的,创建的每个对象和变量都会占据内存,gc做的就是对象清除将内存释放出来。其中堆是虚拟机中进行垃圾回收的主要场所,其次是方法区。
2. 垃圾回收器
新生代收集器:
Serial:是一类用于新生代的单线程收集器,采用复制算法。
ParNew:是Serial的多线程版本。
Parallel Scavenge:多线程收集器,其注重点在于尽可能的缩短垃圾收集时用户线程的停顿时间。
老年代收集器:
Serial Old:是Serial收集器的老年代版本,也是单线程收集器,采用标记-整理算法。
Parallel Old:是Parallel收集器的老年代版本,采用标记-整理算法。
CMS:一种以获取最短回收停顿时间为目标的收集器。采用的算法是“标记-清除”。
新生代和老年代收集器:
G1收集器:G1收集器是一款面向服务端应用的垃圾收集器,目前是JDK9的默认垃圾收集器。
3. Java详细信息
java -XX:+PrintCommandLineFlags -version
cmd展示信息:
C:\Users\xx>java -XX:+PrintCommandLineFlags -version
-XX:InitialHeapSize=266295296 -XX:MaxHeapSize=4260724736 -XX:+PrintCommandLineFlags -XX:+UseCompressedClassPointers -XX:+UseCompressedOops -XX:-UseLargePagesIndividualAllocation -XX:+UseParallelGC
java version "1.8.0_91"
Java(TM) SE Runtime Environment (build 1.8.0_91-b14)
Java HotSpot(TM) 64-Bit Server VM (build 25.91-b14, mixed mode)
JDK1.8默认使用的垃圾回收器是-XX:+UseParallelGC,代表为 “Parallel Scavenge” + “Parallel Old”。
在JVM中垃圾回收器配置实现的搭配组合如下:
默认垃圾回收方式 | 代表垃圾回收器 |
---|---|
UseSerialGC | “Serial” + “Serial Old” |
UseParNewGC | “ParNew” + “Serial Old” |
UseConcMarkSweepGC | “ParNew” + “CMS” |
UseParallelGC | “Parallel Scavenge” + “Parallel Old” |
4. GC优化条件
若满足一下条件,则GC一般不需要优化。
■ Minor GC执行时间不超过50ms;
■ Minor GC执行不频繁,大概10秒执行一次;
■ Full GC执行时间不到1s;
■ Full GC执行频率不算频繁,不低于10分钟1次。