当前位置:   article > 正文

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

1.8默认的垃圾回收器

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展示信息:

  1. C:\Users\xx>java -XX:+PrintCommandLineFlags -version
  2. -XX:InitialHeapSize=266295296 -XX:MaxHeapSize=4260724736 -XX:+PrintCommandLineFlags -XX:+UseCompressedClassPointers -XX:+UseCompressedOops -XX:-UseLargePagesIndividualAllocation -XX:+UseParallelGC
  3. java version "1.8.0_91"
  4. Java(TM) SE Runtime Environment (build 1.8.0_91-b14)
  5. 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次。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小惠珠哦/article/detail/907705
推荐阅读
相关标签
  

闽ICP备14008679号