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

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值