JDK1.8使用的垃圾回收器和执行GC的时长以及GC的频率

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次。

你可能感兴趣的:(架构师之路,jvm,java,算法)