JVM深入原理(八)(二):垃圾回收

简介: Java垃圾回收过程会通过单独的GC线程来完成,但是不管使用哪一种GC算法,都会有部分阶段需要停止所有的用户线程。这个过程被称之为StopTheWorld简称STW,如果STW时间过长则会影响用户的使用。一般来说,堆内存越大,最大STW就越长,想减少最大STW,就会减少吞吐量,不同的GC算法适用于不同的场景。分代回收算法将整个堆中的区域划分为新生代和老年代。--超过新生代大小的大对象会直接晋升到老年代。

JVM系列文章

  1. 深入理解JVM,包含字节码文件,内存结构,垃圾回收,类的声明周期,类加载器_eden used total max-CSDN博客
  2. JVM深入原理(一+二):JVM概述和JVM功能-CSDN博客
  3. JVM深入原理(三+四):JVM组成和JVM字节码文件-CSDN博客
  4. JVM深入原理(五):JVM组成和JVM字节码文件-CSDN博客
  5. JVM深入原理(六)(一):JVM类加载器-CSDN博客
  6. JVM深入原理(六)(二):双亲委派机制-CSDN博客
  7. JVM深入原理(七)(一):运行时数据区-CSDN博客
  8. JVM深入原理(七)(二):运行时数据区-CSDN博客
  9. JVM深入原理(八)(一):垃圾回收-CSDN博客
  10. JVM深入原理(八)(二):垃圾回收-CSDN博客

目录

8.6. 垃圾回收-算法

8.6.1. 算法评判标准

8.6.2. 标记-清除算法

8.6.3. 标记-整理算法

8.6.4. 复制算法

8.6.5. 分代垃圾回收算法

8.6.5.1. 分代垃圾回收算法-结构

8.6.5.2. 对象存储和垃圾回收过程

8.6.5.3. 相关JVM参数

8.7. 垃圾回收器

8.7.1. 串行垃圾回收器

8.7.2. 吞吐量优先垃圾回收器

8.7.3. 响应时间优先垃圾回收器

8.7.4. G1

8.7.4.1. G1垃圾回收阶段

8.7.4.2. Young Collection

8.7.4.3. Young Collection + Concurrent Mark

8.7.4.4. Mixed Collection


8.6. 垃圾回收-算法

8.6.1. 算法评判标准

Java垃圾回收过程会通过单独的GC线程来完成,但是不管使用哪一种GC算法,都会有部分阶段需要停止所有的用户线程。这个过程被称之为StopTheWorld简称STW,如果STW时间过长则会影响用户的使用。

image.gif 编辑

评判GC算法从三个维度:

  1. 吞吐量:吞吐量越大说明GC算法效率越高,吞吐量=(代码执行时间)/(代码执行时间+GC时间)
  2. 最大暂停时间:最大STW时间越小效率越高,最大暂停时间指的是所有垃圾回收过程STW的最大值
  3. 堆的使用效率:不同的垃圾回收算法堆堆的使用效率是不同的,标记-整理算法可以使用完整的堆,而复制算法将堆一分为二,只能使用一半的堆

一般来说,堆内存越大,最大STW就越长,想减少最大STW,就会减少吞吐量,不同的GC算法适用于不同的场景

8.6.2. 标记-清除算法

标记清除算法分为两个阶段:

  1. 标记:先沿着GC Roots对象的引用链寻找未被引用的对象,标记起来
  2. 清除:将未被引用的对象垃圾回收掉

标记清除算法的优缺点:

  • 优点:效率高速度快
  • 缺点:容易产生内存碎片,分配新的对象时需要遍历整个空间才能得出是否有空间分配

8.6.3. 标记-整理算法

标记整理算法

  • 介绍:在标记清除算法的基础上多一步整理内存空间过程
  • 优点:不会产生内存碎片
  • 缺点:移动对象会改变所有引用了该地址的对象,速度慢

8.6.4. 复制算法

复制算法

  • 介绍:开辟两块一模一样的内存空间,先标记未应用的对象后,将已引用的对象复制到未使用的内存空间,清空原来空间,再交换两者的位置
  • 优点:不会产生内存碎片
  • 缺点:占用双倍内存空间

8.6.5. 分代垃圾回收算法

8.6.5.1. 分代垃圾回收算法-结构

分代回收算法将整个堆中的区域划分为新生代和老年代

image.gif 编辑

  • 新生代:存放存活时间短的对象
  • eden区:
  • survivor s0
  • survivor s1
  • 老年代:存放存活时间长的对象

8.6.5.2. 对象存储和垃圾回收过程

  1. 对象首先分配在eden区中
  2. eden区内存不足时会触发minor gc,eden区和survivor From区存活的对象使用复制算法复制到survivor to区中,存活对象寿命+1,并交换From和To区,以此往复
  3. minor gc会触发一次stop the world,暂停其他用户线程,等待垃圾回收完毕,用户线程才恢复运行
  4. 当对象寿命达到阈值时会转移到老年代中,最大寿命是15
  5. 老年代内存不足时,会先尝试触发minor gc,如果内存仍不足,会触发full gc,stw时间更长,采用的是标记整理算法

--超过新生代大小的大对象会直接晋升到老年代

8.6.5.3. 相关JVM参数

image.gif 编辑

8.7. 垃圾回收器

8.7.1. 串行垃圾回收器

  • 特点:单线程,垃圾回收时其他线程都暂停
  • 使用场景:堆内存较小,单核CPU
  • 流程图:serial新生代(复制)+serialOld(标记整理)

    image.gif 编辑

8.7.2. 吞吐量优先垃圾回收器

  • 特点:多线程,尽可能让每次stop the world回收的垃圾数量多,类似多食少餐,并行,多个CPU运行单个垃圾回收线程
  • 使用场景:堆内存较大,多核CPU
  • 流程图:

    image.gif 编辑
  • -XX:+UseParallelGC~-XX:+UseParallel0ldGC:开启并行垃圾回收器,这个参数同时影响新生代和老年代,JDK8下默认开启
  • -XX:+UseAdaptiveSizePolicy:采用动态自适应新生代大小空间分配
  • -XX:GCTimeRatio=ratio:调整吞吐量大小,垃圾回收时间=1/(1+radio)
  • -XX:MaxGCPauseMillis=ms:调整暂停时间
  • -XX:ParallelGCThreads=n:控制parallelgc工作时的线程数

8.7.3. 响应时间优先垃圾回收器

  • 特点:多线程,尽可能让每次stop the world的时间尽可能短,类似少食多餐,并发,单个CPU运行垃圾回收线程和用户线程,只有在并发gc清理垃圾速度跟不上垃圾产生速度的时候才会产生full gc
  • 使用场景:堆内存较大,多核CPU
  • 流程图:

    image.gif 编辑
  • -XX:+UseConcMarkSweepGC~-XX:+UseParNewGC~SerialOld
  • XX:ParallelGCThreads=n~-XX:ConcGCThreads=threads-
  • XX:CMSInitiatingOccupancyFraction=percent-
  • XX:+CMSScavengeBeforeRemark

8.7.4. G1

  • 定义:garbage first,只有在并发gc清理垃圾速度跟不上垃圾产生速度的时候才会产生full gc
  • 适用场景:
  • 同时注重吞吐量和低响应时间,默认STW时间是200ms
  • 超大堆内存,会将堆划分为多个大小相等的区域
  • 整体上是标记整理算法,两个区域之间是复制算法
  • 相关JVM参数
  • -XX:+UseG1GC:JDK8以前开启G1垃圾回收器
  • -XX:G1HeapRegionSize=size
  • -XX:MaxGCPauseMillis=time

8.7.4.1. G1垃圾回收阶段

image.gif 编辑

8.7.4.2. Young Collection

image.gif 编辑

  • 初始创建的对象存放在eden区
  • 经历一次垃圾回收后对象存放在survivor区
  • 对象寿命达到阈值后经过复制算法存放在老年代

8.7.4.3. Young Collection + Concurrent Mark

image.gif 编辑

  • Young GC时会进行GC Root的初始标记
  • 老年代占用堆空间的比例达到阈值时,会触发并发标记
  • -XX:InitiatingHeapOccupancyPercent=percent(默认45%):调整阈值

8.7.4.4. Mixed Collection

image.gif 编辑

  • 会对eden区,survivor区,老年代的对象进行full gc
  • 优先回收垃圾最多的区域,保证一次回收的垃圾释放最多的空间
  • 最终标记会stw
  • 拷贝存货会stw
  • -XX:MaxGCPauseMillis=ms
目录
相关文章
|
26天前
|
Arthas 存储 算法
深入理解JVM,包含字节码文件,内存结构,垃圾回收,类的声明周期,类加载器
JVM全称是Java Virtual Machine-Java虚拟机JVM作用:本质上是一个运行在计算机上的程序,职责是运行Java字节码文件,编译为机器码交由计算机运行类的生命周期概述:类的生命周期描述了一个类加载,使用,卸载的整个过类的生命周期阶段:类的声明周期主要分为五个阶段:加载->连接->初始化->使用->卸载,其中连接中分为三个小阶段验证->准备->解析类加载器的定义:JVM提供类加载器给Java程序去获取类和接口字节码数据类加载器的作用:类加载器接受字节码文件。
188 55
|
26天前
|
Oracle Java 关系型数据库
JVM深入原理(一+二):JVM概述和JVM功能
JVM全称是Java Virtual Machine-Java虚拟机JVM作用:本质上是一个运行在计算机上的程序,职责是运行Java字节码文件,编译为机器码交由计算机运行。
54 0
|
26天前
|
Arthas 存储 Java
JVM深入原理(三+四):JVM组成和JVM字节码文件
目录3. JVM组成3.1. 组成-运行时数据区3.2. 组成-类加载器3.3. 组成-执行引擎3.4. 组成-本地接口4. JVM字节码文件4.1. 字节码文件-组成4.1.1. 组成-基础信息4.1.1.1. 基础信息-魔数4.1.1.2. 基础信息-主副版本号4.1.2. 组成-常量池4.1.3. 组成-方法4.1.3.1. 方法-工作流程4.1.4. 组成-字段4.1.5. 组成-属性4.2. 字节码文件-查看工具4.2.1. javap4.2.2. jclasslib4.2.3. 阿里Arthas
35 0
|
26天前
|
存储 安全 Java
JVM深入原理(五):JVM组成和JVM字节码文件
类的生命周期概述:类的生命周期描述了一个类加载,使用,卸载的整个过类的生命周期阶段:类的声明周期主要分为五个阶段:加载->连接->初始化->使用->卸载,其中连接中分为三个小阶段验证->准备->解析。
26 0
|
26天前
|
Arthas Java 测试技术
JVM深入原理(六)(一):JVM类加载器
目录6. JVM类加载器6.1. 类加载器-概述6.2. 类加载器-执行流程6.3. 类加载器-分类(JDK8)6.3.1. JVM底层实现的类加载器6.3.1.1. 启动类加载器6.3.2. Java代码实现类的加载器6.3.2.1. 扩展类加载器6.3.2.2. 应用程序类加载器6.4. 类加载器-Arthas查看类加载器
28 0
|
26天前
|
Java 关系型数据库 MySQL
JVM深入原理(六)(二):双亲委派机制
自定义类加载器打破双亲委派机制的方法:复写ClassLoader中的loadClass方法常见问题:要加载的类名如果是以java.开头,则会抛出安全性异常加载自定义的类都会有一个共同的父类Object,需要在代码中交由父类加载器去加载自定义类加载器不手动指定parent会默认指定应用类加载两个自定义类加载器加载同一个类会被认为是两个对象,只有相同的类加载器+想通的类限定名才会被认为是一个对象。
33 0
|
26天前
|
存储 安全 Java
JVM深入原理(七)(一):运行时数据区
栈的介绍:Java虚拟机栈采用栈的数据结构来管理方法调用中的基本数据,先进后出,每一个方法的调用使用一个栈帧来保存栈的组成:栈:一个线程运行所需要的内存空间,一个栈由多个栈帧组成栈帧:一个方法运行所需要的内存空间活动栈帧:一个线程中只能有一个活动栈帧栈的生命周期:栈随着线程的创建而创建,而回收会在线程销毁时进行栈的执行流程:栈帧压入栈内执行方法执行完毕释放内存若方法间存在调用,那么会压入被调用方法入栈,执行完后释放内存,再执行当前方法,直到执行完毕,释放所有内存。
28 0
|
26天前
|
存储 缓存 安全
JVM深入原理(七)(二):运行时数据区
堆的作用:存放对象的内存空间,它是空间最大的一块内存区域.栈上的局部变量表中,可以存放堆上对象的引用。静态变量也可以存放堆对象的引用,通过静态变量就可以实现对象在线程之间共享。堆的特点:线程共享:堆中的对象都需要考虑线程安全的问题垃圾回收:堆有垃圾回收机制,不再引用的对象就会被回收方法区的概述:方法区是存放基础信息的位置,线程共享,主要包括:类的元信息:保存了所有类的基本信息运行时常量池:保存了字节码文件中的常量池内容静态常量池:字节码文件通过编号查表的方式找到常量。
28 0
|
26天前
|
缓存 算法 Java
JVM深入原理(八)(一):垃圾回收
弱引用-作用:JVM中使用WeakReference对象来实现软引用,一般在ThreadLocal中,当进行垃圾回收时,被弱引用对象引用的对象就直接被回收.软引用-作用:JVM中使用SoftReference对象来实现软引用,一般在缓存中使用,当程序内存不足时,被引用的对象就会被回收.强引用-作用:可达性算法描述的根对象引用普通对象的引用,指的就是强引用,只要有这层关系存在,被引用的对象就会不被垃圾回收。引用计数法-缺点:如果两个对象循环引用,而又没有其他的对象来引用它们,这样就造成垃圾堆积。
49 0
|
3月前
|
存储 算法 Java
G1原理—5.G1垃圾回收过程之Mixed GC
本文介绍了G1的Mixed GC垃圾回收过程,包括并发标记算法详解、三色标记法如何解决错标漏标问题、SATB如何解决错标漏标问题、Mixed GC的过程、选择CollectSet的算法
G1原理—5.G1垃圾回收过程之Mixed GC