JVM垃圾回收的普遍步骤

2024-06-15 00:44

本文主要是介绍JVM垃圾回收的普遍步骤,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

JVM(Java Virtual Machine)进行垃圾回收时,通常遵循以下步骤。不同的垃圾收集器可能会有一些不同的实现细节,但基本步骤和思想大致相同。以下是一般的垃圾回收过程的主要步骤:

1. 标记阶段(Marking Phase)

  • 可达性分析:JVM 会从根对象(GC Roots)开始,遍历所有引用并标记所有可达对象。
    • GC Roots 包括:
      • 活动线程栈中的局部变量
      • 静态变量
      • JNI 引用
      • 已加载的类
  • 标记对象:所有被引用的对象都会被标记为可达对象。

2. 清除阶段(Sweeping Phase)

  • 删除不可达对象:未被标记的对象被视为垃圾,将会被删除。
  • 回收空间:回收被删除对象占用的内存空间。

3. 压缩阶段(Compacting Phase)

  • 对象移动:将存活的对象压缩到内存的一端,以便腾出连续的内存空间。
  • 更新引用:更新所有指向被移动对象的引用,以确保引用的正确性。

4. 分代回收(Generational Collection)

  • 新生代(Young Generation):主要用于存放新创建的对象,包括以下三个区域:
    • Eden 区:大部分新对象首先在这里分配。
    • Survivor 区:两个 Survivor 区(S0 和 S1),用于在新生代之间复制存活的对象。
    • Minor GC:当 Eden 区满时触发 Minor GC,将存活对象复制到 Survivor 区或晋升到老年代。
  • 老年代(Old Generation):用于存放生命周期较长的对象。
    • Major GC/Full GC:当老年代满时触发 Major GC 或 Full GC,这个过程通常比 Minor GC 更耗时。

5. 特殊的垃圾回收器

  • Serial GC:单线程垃圾收集器,适用于单处理器环境。
  • Parallel GC:多线程垃圾收集器,适用于多处理器环境,着重于吞吐量。
  • CMS(Concurrent Mark-Sweep)GC:并发标记清除垃圾收集器,旨在减少停顿时间。
  • G1(Garbage-First)GC:分区垃圾收集器,兼顾低停顿和高吞吐量,适用于大堆内存。

示例流程

以下是一个典型的垃圾回收过程(以 G1 GC 为例):

  1. 初始标记(Initial Marking):标记从 GC Roots 直接可达的对象。这阶段会暂停所有应用线程(STW)。
  2. 并发标记(Concurrent Marking):遍历对象图,标记所有可达对象。此阶段与应用线程并发执行。
  3. 最终标记(Final Marking):处理在并发标记阶段发生变化的对象。会有短暂的 STW。
  4. 筛选回收(Live Data Counting and Evacuation):计算存活对象并选择回收区域,将存活对象移动到新区域,回收旧区域。

垃圾回收示意图

1. 标记阶段(Marking Phase)- 可达性分析:GC Roots -> 标记所有可达对象2. 清除阶段(Sweeping Phase)- 删除不可达对象 -> 回收内存空间3. 压缩阶段(Compacting Phase)- 移动存活对象 -> 更新引用4. 分代回收(Generational Collection)- 新生代(Young Generation):Eden、Survivor -> Minor GC- 老年代(Old Generation) -> Major GC/Full GC5. 特殊的垃圾回收器- Serial GC、Parallel GC、CMS GC、G1 GC

总结

JVM 的垃圾回收过程包括标记、清除、压缩等阶段,结合分代回收机制来高效地管理内存。不同的垃圾收集器根据不同的需求和环境进行优化,以达到最佳的性能和最小的停顿时间。了解这些步骤和原理可以帮助开发者优化 Java 应用的性能和稳定性。

这篇关于JVM垃圾回收的普遍步骤的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1061956

相关文章

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

Springboot @Autowired和@Resource的区别解析

《Springboot@Autowired和@Resource的区别解析》@Resource是JDK提供的注解,只是Spring在实现上提供了这个注解的功能支持,本文给大家介绍Springboot@... 目录【一】定义【1】@Autowired【2】@Resource【二】区别【1】包含的属性不同【2】@

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J

Java中的String.valueOf()和toString()方法区别小结

《Java中的String.valueOf()和toString()方法区别小结》字符串操作是开发者日常编程任务中不可或缺的一部分,转换为字符串是一种常见需求,其中最常见的就是String.value... 目录String.valueOf()方法方法定义方法实现使用示例使用场景toString()方法方法

Java中List的contains()方法的使用小结

《Java中List的contains()方法的使用小结》List的contains()方法用于检查列表中是否包含指定的元素,借助equals()方法进行判断,下面就来介绍Java中List的c... 目录详细展开1. 方法签名2. 工作原理3. 使用示例4. 注意事项总结结论:List 的 contain

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("