当前位置: 首页 > news >正文

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

相关文章:

  • wordpress 关闭xmlrpc/好的推广平台
  • 中国商城网站建设/如何在各种网站投放广告
  • 涞水网站建设/长沙网络营销公司
  • wordpress 访问页面/临沂seo代理商
  • wordpress缩略图不显示/关键词权重
  • 搭建平台畅通渠道/嘉峪关seo
  • 【Django项目开发】django的信号机制(八)
  • JUC面试(一)——JUCJMMvolatile 1.0
  • Xinlinx zynq7020国产替代 FMQL20S400 全国产化 ARM 核心板+扩展板
  • Go语言开发小技巧易错点100例(五)
  • 算法leetcode|31. 下一个排列(rust重拳出击)
  • SpringCloud-Netflix学习笔记03——什么是Eureka
  • 测试篇(二): 如何合理的创建bug、bug的级别、bug的生命周期、跟开发产生争执怎么办
  • springboot 项目自定义log日志文件提示系统找不到指定的文件
  • 【数据结构与算法】顺序表的原理及实现
  • 【C进阶】动态内存管理
  • GTD之初总结
  • 【Unity URP】设置光源层Light Layers