说下JVM中一次完整的GC流程?

大家好,我是锋哥。今天分享关于【说下JVM中一次完整的GC流程?】面试题。希望对大家有帮助;

说下JVM中一次完整的GC流程?

1000道 互联网大厂Java工程师 精选面试题-Java资源分享网

在JVM中,垃圾回收(GC) 是自动化内存管理的一部分,用于回收不再被引用的对象,释放内存资源。JVM的GC主要通过标记、清除和压缩等算法来管理内存。GC的过程较为复杂,涉及多个阶段和多个垃圾回收器。下面是一次完整的垃圾回收流程的详细介绍。

1. GC触发条件

GC的触发条件有多个,主要包括:

  • 堆内存不足:当JVM中的堆内存(年轻代、老年代)不足时,会触发GC。
  • 显式调用System.gc():调用该方法会触发GC,但JVM不一定会立刻执行。
  • 内存分配失败:在分配内存时,如果不能从堆中找到足够的空间,也会触发GC。
  • 老年代的空间不足:年轻代的GC不足以回收老年代所需的空间时,会触发Full GC。

2. GC的分代理论

JVM的堆内存通常分为三个区域:

  • 年轻代(Young Generation):包含新创建的对象。年轻代又分为三个区域:
    • Eden空间:新创建的对象首先会被分配到Eden区。
    • Survivor空间(S0, S1):Eden区存活下来的对象会被复制到其中一个Survivor空间。两个Survivor区交替使用。
  • 老年代(Old Generation):经过多次GC后仍然存活的对象会被提升到老年代。
  • 永久代(PermGen):用于存储类的元数据(JVM 8后被MetaSpace取代)。

3. GC的基本步骤

1) 年轻代GC(Minor GC)

年轻代GC发生在年轻代内存不足时,步骤如下:

  • 标记阶段
    • JVM首先会标记出年轻代中存活的对象。标记对象是通过引用计数可达性分析的方式确定的。
    • 在这个阶段,Root(如栈上的局部变量、静态变量等)会作为起始点,通过引用关系递归地遍历所有可达对象。
  • 复制阶段
    • 对象存活标记完成后,JVM会将存活的对象从Eden区复制到其中一个Survivor区。如果当前Survivor区已满,则会将对象转移到老年代。
    • 如果Survivor区的空间不足以容纳所有存活的对象,就会触发老年代GC(Full GC)。
  • 清理阶段
    • Eden区和原先的Survivor区会被清空,释放空间供新的对象使用。
2) 老年代GC(Major GC 或 Full GC)

老年代GC通常是在年轻代GC不能有效回收内存时发生,尤其是当老年代空间不足时触发。此时JVM会进行整个堆的垃圾回收:

  • 标记阶段
    • 对象的标记和年轻代GC相似,通过可达性分析标记存活对象。
  • 清理阶段
    • 清理所有未被标记的对象,释放内存空间。
  • 压缩阶段
    • 在老年代GC后,可能会进行内存压缩。即将存活的对象移到内存的一端,释放出连续的空闲内存。
3) GC算法

JVM中常用的GC算法包括:

  • 标记-清除(Mark-Sweep)
    • 标记所有存活的对象,然后清除未标记的对象。缺点是会产生内存碎片。
  • 复制算法(Copying)
    • 适用于年轻代的GC。将存活对象从一个区域复制到另一个区域,清空源区域,避免内存碎片。
  • 标记-整理(Mark-Compact)
    • 适用于老年代的GC。标记所有存活的对象并将其压缩到堆的一端,避免内存碎片。
  • 分代收集
    • 根据不同的对象生命周期,年轻代和老年代使用不同的GC算法来提高效率。年轻代采用复制算法,老年代采用标记-清除或标记-整理。

4. GC的执行过程

一个完整的GC过程可以分为以下几个步骤:

  1. GC Root Tracing:JVM会从GC Roots开始,通过引用链追踪可达的对象。
  2. 标记阶段:标记所有存活的对象,GC通过可达性分析找到所有从GC Root可达的对象。
  3. 清除阶段:对于未被标记的对象(即不可达的对象),会被清除。
  4. 压缩阶段(仅老年代GC时执行):将存活的对象移动到内存的一端,释放连续的空间。

5. GC类型

JVM有多种垃圾回收器,每个垃圾回收器的工作方式不同,常见的回收器包括:

  • Serial GC:单线程进行GC,适用于单核或小内存系统。
  • Parallel GC:多线程GC,适用于多核CPU。
  • CMS(Concurrent Mark-Sweep):旨在减少GC停顿时间的回收器,适用于低延迟需求。
  • G1 GC:一个面向大内存和低延迟的垃圾回收器,按区域划分堆内存,优化GC时间。

6. Full GC vs Minor GC

  • Minor GC:发生在年轻代,通常速度较快,但会对性能有轻微影响。
  • Full GC:发生在整个堆(包括年轻代和老年代),通常会暂停应用程序的执行较长时间,因此影响性能较大。

7. GC的停顿时间

  • Stop-the-World:在GC过程中,JVM会暂停应用程序的执行,这被称为"Stop-the-World"事件。垃圾回收器使用不同的算法来减少停顿时间,如G1 GC通过分区域处理减少单次GC停顿时间。

总结

一次完整的GC过程涉及:

  1. 触发条件(如内存不足、显式调用等);
  2. 垃圾回收的不同阶段(如标记、清理、压缩等);
  3. 多种GC算法(如标记-清除、复制算法等);
  4. 多种GC回收器(如Serial、Parallel、CMS、G1等)。

垃圾回收的目标是高效地回收内存,同时尽可能减少对应用程序性能的影响。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/489256.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Leetcode 每日一题9.回文数

🌈🌈🌈今天给大家分享的是:回文数的解法 目录 ​编辑 问题描述 输入输出格式 示例 约束条件 进阶挑战 解决方案 问题分析 过题图片 字符串转换法 数学方法 算法解释 题目链接 结论 问题描述 给定一个整数 x,我们需要…

得物App奢侈品鉴别能力再获A级资质认证

11月20日,在中国出入境检验检疫协会举办的“2024高端消费品检验鉴定与市场可持续发展大会”上传出消息,得物App因“先鉴别、后发货”保障正品的突出表现以及较高的消费者认可度,被中国海关科学技术研究中心授予“奢侈品鉴别(箱包类…

word表格里面的文字首行有空格删除不掉怎么办

1、问题 这里首行的文字一直有空格,删除不掉,且用段落调整首行缩进也一直没用; 改成无,然后一直没有用; 2、改进方法 用这个清除一个表格的格式后,后面所有表格的格式都会更新;再重新按照段落…

CNCF云原生生态版图-项目和产品综合分析

CNCF云原生生态版图-项目和产品综合分析 CNCF云原生生态版图-项目和产品综合分析整体统计分析中国研发人员贡献项目和产品其中,纳入 CNCF 管理的开源项目 链接 CNCF云原生生态版图-项目和产品综合分析 整体统计分析 在对云原生技术选型时,优先选择经过 …

Unity3D下采集camera场景并推送RTMP服务实现毫秒级延迟直播

技术背景 好多开发者,希望我们能够分享下如何实现Unity下的camera场景采集并推送rtmp服务,然后低延迟播放出来。简单来说,在Unity 中实现采集 Camera 场景并推送RTMP的话,先是获取 Camera 场景数据,通过创建 RenderTex…

SEC_ASA 第一天作业

拓扑: 实验需求: 注意:在开始作业之前必须先读“前言”,以免踩坑!!!(☞敢点我试试) 按照拓扑图配置VLAN连接。 注意:ASA防火墙的 Gi0/1口需要起子接口&#x…

【电子元器件】电感基础知识

本文章是笔者整理的备忘笔记。希望在帮助自己温习避免遗忘的同时,也能帮助其他需要参考的朋友。如有谬误,欢迎大家进行指正。 一、 电感的基本工作原理 1. 电感的基本工作原理如下: (1) 当线圈中有电流通过时&#…

使用枚举实现单例模式,不会反序列化破坏攻击,不会被反射破坏攻击。(附带枚举单例的简单实现)

原因分析 1.反序列化方法 ① jdk8中的Enum源码中对反序列化方法进行重写,抛出异常。 java.lang.Enum#readObject方法截图如下 ②java.io.ObjectInputStream#readObject 方法中的 readEnum 方法处理了枚举类型的反序列化,从而确保了枚举的单例特性。 …

vue3 封装request请求

vue3 原生请求封装 我这里用一个案例来解释 需求:把vue3原生的静态页 集成到 vue2 的若依项目 并且可以访问 vue2接口 在vue3 src 下的 utils 下 创建文件request.ts文件 import axios from "axios"; import { showMessage } from "./status"; // 引入状态…

Python-消息队列模块queue使用指南

queue 模块是 Python 标准库中的一个重要模块,主要用于提供线程安全的队列类,适用于多线程编程中不同线程之间的数据交换。它提供了 3 种类型的队列: queue.Queue:FIFO(先进先出)队列queue.LifoQueue&…

打造高效Android远程开发环境:一键部署Docker-Android并发布公网

文章目录 前言1. 虚拟化环境检查2. Android 模拟器部署3. Ubuntu安装Cpolar4. 配置公网地址5. 远程访问小结 6. 固定Cpolar公网地址7. 固定地址访问 💡 推荐 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分…

EFAK kafka可视化管理工具部署使用

简介:EFAK是开源的可视化和管理软件。它允许您查询、可视化、提醒和探索您的指标,无论它们存储在何处。简单来说,它为您提供了将 Kafka 集群数据转换为漂亮的图形和可视化效果的工具。 环境:①操作系统:CentOS7.6&…

【机器人】轨迹规划 之 spline 规划

在轨迹规划中,使用 spline (通常是指通过样条曲线进行轨迹规划)可以实现平滑、连续的路径。以下是使用样条(如B样条、三次样条插值)的具体方法和步骤,结合一个简单的例子说明: 示例场景&#xf…

重生之我在异世界学编程之C语言:深入文件操作篇(上)

大家好,这里是小编的博客频道 小编的博客:就爱学编程 很高兴在CSDN这个大家庭与大家相识,希望能在这里与大家共同进步,共同收获更好的自己!!! 函数递归与迭代 引言正文一、为什么要用文件二、文…

【Linux】Systemtap在CentsOS9上测试成功了

在Ubuntu上测试没有成功,先看看运行成功的效果吧: 看到运行的效果,可以安心些,哈哈 指导操作来源于这里:SystemTap 主要来源于这里: https://sourceware.org/systemtap/SystemTap_Beginners_Guide/using-s…

厦门凯酷全科技有限公司深耕抖音电商运营

在数字经济飞速发展的今天,抖音电商平台以其独特的社交属性和庞大的用户基础,迅速成为众多品牌和商家的新战场。在这个充满机遇与挑战的市场中,厦门凯酷全科技有限公司凭借其专业的服务、创新的理念和卓越的执行力,成为了抖音电商…

Vue Web开发(五)

1. axios axios官方文档 异步库axios和mockjs模拟后端数据,axios是一个基于promise的HTTP库,使用npm i axios。在main.js中引入,需要绑定在Vue的prototype属性上,并重命名。   (1)main.js文件引用 imp…

【NextJS】路由之拦截路由(Intercepting Routes) - 简仿花瓣网

拦截路由(Intercepting Routes) link: https://nextjs.org/docs/app/building-your-application/routing/intercepting-routes 概念 拦截路由允许在当前布局中加载应用程序其他部分的路由,即在不切换用户上下文的情况下显示路由内容。例如&am…

【Vulkan入门】14-ShowBySDL

文章目录 先叨叨关键代码Git信息main.cpp 运行结果接下来我会做什么重构代码在b站出一套视频 先叨叨 上篇我们让Vulkan渲染了一个三角形,但还没有把它显示出来。本篇介绍一下,如何使用SDL将这个图形显示出来。 原理其实很简单,就是将渲染的内…

GESP202412 四级【Recamán】题解(AC)

》》》点我查看「视频」详解》》》 [GESP202412 四级] Recamn 题目描述 小杨最近发现了有趣的 Recamn 数列,这个数列是这样生成的: 数列的第一项 a 1 a_1 a1​ 是 1 1 1;如果 a k − 1 − k a_{k-1}-k ak−1​−k 是正整数并且没有在数…