JVM垃圾回收的过程

作者: 熊聘 | 来源:发表于2020-07-03 10:16 被阅读0次

JVM垃圾回收的算法很多,但是不管是哪种算法,在进行GC时大致的流程都是差不多的,主要有以下3个过程:

1. 枚举根节点

这个过程主要是找到所有的GC Roots对象,这些对象一般发生在JVM虚拟机栈栈帧、常量池中的静态对象、方法区中静态类属性引用、本地方法栈中引用的对象。这个过程会发生STW,所有的线程均运行到安全区域(Safe Region)才开始执行。

通常有两种算法:
  • 引用计数法:每个对象中添加一个引用计数器,每当有一个地方引用它时,计数器值就+1;当引用失效时,计数器值就-1;任何时刻计数器为0的对象就是不可能在被使用的。

优点是效率高,缺点是循环引用无法处理,导致内存溢出

  • 可达性分析:以GC Roots为根节点,从这些根节点开始向下搜索,搜索所走过的路径称为引用链(Reference Chain),当一个对象不在任何引用链相连时,则证明此对象是不可用的。

优点可以检测所有的对象,缺点效率低

GC Roots节点一般为:
  • 虚拟机栈中栈帧引用的对象
  • 本地方法栈JNI中栈帧引用的对象
  • 常量池中引用的对象
  • 类中的静态变量应用的对象

2. 标记

标记的过程主要是标记哪些对象是需要被回收的,有的GC算法是并行的,有的是和GC Roots标记一起执行。如果是并行的,不会发生STW。

如果是并发标记的GC算法,后面还有有一次重新标记或者最终标记。这主要是来解决在并发标记的过程中,用户线程还在一直执行,这期间有变化的对象。

标记算法常见的有两种:
  • 标记–清除算法或者标记–整理算法:为每个对象存储一个标记位,记录对象的状态(活着或是死亡)

  • 复制算法:将内存平均分成两部分,然后每次只使用其中的一部分,当这部分内存满的时候,将内存中所有存活的对象复制到另一个内存中,然后将之前的内存中死亡的对象清空。

3. 清除或回收

这个阶段会根据GC算法的不同采取不同的回收策略。

  • CMS算法在回收的时候会考虑停顿时间,尽量减少GC线程占用的时间
  • G1算法先对各个Region的回收价值和成本进行排序,根据用户所期望的GC停顿时间来制定回收计划
  • 标记-清除算法在第二阶段(清除阶段)将对象回收
  • 复制算法是通过将存活对象复制到另一块内存区域,将当前区域中未被复制的对象进行清除

相关知识点

相关文章

  • 垃圾回收

    如何查看当前JVM使用的垃圾回收器? 如何指定使用CMS回收? 如何打印回收日志? 垃圾回收过程 CMS垃圾回收的...

  • 架构师训练营第9周作业 JVM垃圾回收 秒杀架构

    请简述JVM垃圾回收原理 所谓垃圾回收,指的是JVM将堆空间中不再使用的对象清理掉的过程,这是由JVM自动完成的。...

  • JVM垃圾回收算法

    Java基础:JVM垃圾回收算法 [toc] 参考:Java基础:JVM垃圾回收算法图解JVM垃圾回收算法 总结:...

  • JVM调优之垃圾定位、垃圾回收算法、垃圾处理器对比

    谈垃圾回收器之前,要先讲讲垃圾回收算法,以及JVM对垃圾的认定策略,JVM垃圾回收器是垃圾回收算法的具体实现,了解...

  • JVM垃圾回收机制

    JVM垃圾回收 整体思维导图 带着问题理解JVM垃圾回收机制 Java为什么需要垃圾回收机制; 回收哪部分垃圾; ...

  • JVM耳熟能详的垃圾回收

    JVM耳熟能详的垃圾回收 不管面试,还是实际开发过程中,垃圾回收真的是最重要的一块。下面我们来学习学习JVM 垃圾...

  • Java堆外内存回收方法

    [TOC] 一、JVM内存的分配及垃圾回收 JVM垃圾回收 由于JVM会替我们执行垃圾回收,因此开发者根本不需要关...

  • 2020-04-03 JVM垃圾回收相关文章引用

    这三篇文章总结的非常到位,收藏在这里。 Jvm垃圾回收器(基础篇) Jvm垃圾回收器(算法篇) Jvm垃圾回收器(...

  • JVM垃圾回收的过程

    JVM垃圾回收的算法很多,但是不管是哪种算法,在进行GC时大致的流程都是差不多的,主要有以下3个过程: 1. 枚举...

  • JVM 垃圾回收-03(堆)分代收集理论

    1.产生的过程 对象被jvm垃圾回收,随着对象熬过垃圾收集过程的次数(这里叫为对象的年龄)依据回收对象的年龄将对象...

网友评论

    本文标题:JVM垃圾回收的过程

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