美文网首页
Java垃圾回收器(二)

Java垃圾回收器(二)

作者: taoguan | 来源:发表于2019-10-25 22:01 被阅读0次

垃圾收集器组合

JDK7/8后,HotSpot虚拟机所有收集器及组合(连线),如下图:


image
  • 图中展示了7种不同分代的收集器:
    Serial、ParNew、Parallel Scavenge、Serial Old、Parallel Old、CMS、G1;

  • 而它们所处区域,则表明其是属于新生代收集器还是老年代收集器:
    新生代收集器:Serial、ParNew、Parallel Scavenge;
    老年代收集器:Serial Old、Parallel Old、CMS;
    整堆收集器:G1;

  • 两个收集器间有连线,表明它们可以搭配使用

  • 其中Serial Old作为CMS出现"Concurrent Mode Failure"失败的后备预案

Parallel Scavenge收集器

Parallel Scavenge垃圾收集器因为与吞吐量关系密切,也称为吞吐量收集器(Throughput Collector)。

1、特点

新生代收集器;
采用复制算法;
多线程收集;
目标是达一个可控制的吞吐量(Throughput)

2、应用场景

高吞吐量为目标,即减少垃圾收集时间,让用户代码获得更长的运行时间;
当应用程序运行在具有多个CPU上,对暂停时间没有特别高的要求时,即程序主要在后台进行计算,而不需要与用户进行太多交互;

3、设置参数

(1)"-XX:MaxGCPauseMillis"
控制最大垃圾收集停顿时间,大于0的毫秒数;
MaxGCPauseMillis设置得稍小,停顿时间可能会缩短,但也可能会使得吞吐量下降,因为可能导致垃圾收集发生得更频繁;
(2)"-XX:GCTimeRatio"
设置垃圾收集时间占总时间的比率,0<n<100的整数;
GCTimeRatio相当于设置吞吐量大小;
垃圾收集执行时间占应用程序执行时间的比例的计算方法是:
1 / (1 + n)
例如,选项-XX:GCTimeRatio=19,设置了垃圾收集时间占总时间的5%--1/(1+19);
默认值是1%--1/(1+99),即n=99;
(3)"-XX:+UseAdptiveSizePolicy"
开启这个参数后,就不用手工指定一些细节参数,如:
新生代的大小(-Xmn)、Eden与Survivor区的比例(-XX:SurvivorRation)、晋升老年代的对象年龄(-XX:PretenureSizeThreshold)等;
JVM会根据当前系统运行情况收集性能监控信息,动态调整这些参数,以提供最合适的停顿时间或最大的吞吐量,这种调节方式称为GC自适应的调节策略(GC Ergonomiscs)

这是一种值得推荐的方式
(1)、只需设置好内存数据大小(如"-Xmx"设置最大堆);
(2)、然后使用"-XX:MaxGCPauseMillis"或"-XX:GCTimeRatio"给JVM设置一个优化目标;
(3)、那些具体细节参数的调节就由JVM自适应完成;
这也是Parallel Scavenge收集器与ParNew收集器一个重要区别;

Serial Old收集器

Serial Old是 Serial收集器的老年代版本

1、特点

针对老年代;
采用"标记-整理"算法(还有压缩,Mark-Sweep-Compact);
单线程收集;
Serial/Serial Old收集器运行示意图如下:


image

2、应用场景

主要用于Client模式;
在Server模式有两大用途:

  • 在JDK1.5及之前,与Parallel Scavenge收集器搭配使用(JDK1.6有Parallel Old收集器可搭配);
  • 作为CMS收集器的后备预案,在并发收集发生Concurrent Mode Failure时使用;

相关文章

  • Java 垃圾回收器之G1详解

    Java 垃圾回收器之G1详解 概述 G1垃圾回收器是在Java7 update 4之后引入的一个新的垃圾回收器。...

  • 浅析JAVA的垃圾回收机制(GC)

    1.什么是垃圾回收? 垃圾回收(Garbage Collection)是Java虚拟机(JVM)垃圾回收器提供...

  • JVM的垃圾回收机制

    一、垃圾回收 GC(Garbage Collection):JAVA/.NET中的垃圾回收器。Java是由C++发...

  • 我所知道的-Java垃圾回收机制

    本文章你能知道的内容: Java内存模型 Java堆 对象什么时候回收 垃圾回收算法 垃圾回收器 Java内存模型...

  • Java 常见的垃圾回收器

    Java 常见的垃圾回收器 垃圾回收器 (GC, Garbage Collector)是和具体的 JVM 实现紧密...

  • JVM-007-JVM调优之基础理论

    一、认识Garbage  Garbage,垃圾。 Java回收垃圾的方式是采用垃圾回收器。那么什么是垃圾? 简单的...

  • Java垃圾回收

    1.什么是垃圾回收?垃圾回收(Garbage Collection)是Java虚拟机(JVM)垃圾回收器提供的一种...

  • Android 垃圾回收与内存优化

    一些资料记录: 一、 java内存模型 二、 垃圾回收算法 三、 垃圾回收器对象的新生代、老年代、永久代关系 四、...

  • Java垃圾回收器(二)

    垃圾收集器组合 JDK7/8后,HotSpot虚拟机所有收集器及组合(连线),如下图: 图中展示了7种不同分代的收...

  • Java 垃圾回收器类型

    垃圾收集器类型(已Java8为例) 串行垃圾回收器(Serial Garbage Collector) 串行垃圾回...

网友评论

      本文标题:Java垃圾回收器(二)

      本文链接:https://www.haomeiwen.com/subject/krbevctx.html