JVM中的GC过程

2024-09-06 15:44
文章标签 java jvm 过程 gc

本文主要是介绍JVM中的GC过程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

堆内存结构:在详细讨论GC过程之前,需要了解JVM堆内存的结构。JVM堆内存通常被分为新生代(Young Generation)和老年代(Old Generation),其中新生代又进一步细分为Eden区(Eden Space)和两个Survivor区(S0和S1,也称为From和To区)。从JDK 1.8开始,永久代(Permanent Generation)被元空间(Metaspace)所取代。

  • GC过程:GC过程主要集中在堆内存上,特别是新生代和老年代。新生代中的GC通常称为Minor GC或Young GC,而老年代中的GC则称为Major GC或Full GC

    • Minor GC(Young GC):Minor GC主要发生在新生代,其过程大致如下:

      • 对象分配:新创建的对象首先被分配到Eden区。

      • Eden区满:当Eden区空间不足时,会触发Minor GC

      • 可达性分析:通过可达性分析算法(如根搜索算法)找到存活的对象

      • 复制与清除:将Eden区中的存活对象复制到其中一个Survivor区(如S0),同时清空Eden区。如果Survivor区放不下,则部分对象会晋升到老年代

      • Survivor区交换:在后续的GC中,Eden区和之前存放存活对象的Survivor区(如S0)中的存活对象会被复制到另一个Survivor区(如S1),同时清空这两个区。Survivor区之间会进行角色互换。

      • 年龄晋升:对象在Survivor区每经过一次GC,其年龄就增加1。当对象达到一定年龄(默认是15,可通过-XX:MaxTenuringThreshold设置)后,会被晋升到老年代。

    • Major GC(Full GC):Major GC主要发生在老年代,其触发条件包括:

      • 老年代空间不足:当老年代空间不足以存放晋升的对象时,会触发Major GC。

      • 显式调用:程序中显式调用System.gc()方法时,会建议JVM执行Full GC,但JVM不一定会立即执行。

      • 其他情况:如元空间不足、永久代空间不足(在JDK 1.8之前)等,也可能触发Full GC。

      Major GC的过程通常比Minor GC更复杂,耗时也更长,因为它需要处理的对象更多,且存活率较高。Major GC采用的算法可能包括标记-清除、标记-整理等。

  • GC算法

    GC过程中使用的算法主要有以下几种:

    1. 标记-清除(Mark-Sweep):首先标记出所有需要回收的对象,然后统一回收这些对象。这种方法简单但会产生内存碎片。

    2. 复制(Copying):将内存分为大小相等的两块,每次只使用其中一块。当这块内存用完时,将存活的对象复制到另一块上,然后清空当前块。这种方法解决了内存碎片问题,但代价是内存使用率降低。

    3. 标记-整理(Mark-Compact):标记出所有需要回收的对象,然后让所有存活的对象都向一端移动,最后清理掉边界以外的内存。这种方法既解决了内存碎片问题,又提高了内存使用率。

  • GC对性能的影响

    GC过程中会暂停所有Java执行线程(也称为Stop-The-World),这会对系统性能造成一定影响。为了减少这种影响,现代JVM采用了多种优化技术,如增量GC、并发GC等。

这篇关于JVM中的GC过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux线程同步/互斥过程详解

《Linux线程同步/互斥过程详解》文章讲解多线程并发访问导致竞态条件,需通过互斥锁、原子操作和条件变量实现线程安全与同步,分析死锁条件及避免方法,并介绍RAII封装技术提升资源管理效率... 目录01. 资源共享问题1.1 多线程并发访问1.2 临界区与临界资源1.3 锁的引入02. 多线程案例2.1 为

批量导入txt数据到的redis过程

《批量导入txt数据到的redis过程》用户通过将Redis命令逐行写入txt文件,利用管道模式运行客户端,成功执行批量删除以Product*匹配的Key操作,提高了数据清理效率... 目录批量导入txt数据到Redisjs把redis命令按一条 一行写到txt中管道命令运行redis客户端成功了批量删除k

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Win10安装Maven与环境变量配置过程

《Win10安装Maven与环境变量配置过程》本文介绍Maven的安装与配置方法,涵盖下载、环境变量设置、本地仓库及镜像配置,指导如何在IDEA中正确配置Maven,适用于Java及其他语言项目的构建... 目录Maven 是什么?一、下载二、安装三、配置环境四、验证测试五、配置本地仓库六、配置国内镜像地址

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.