当前位置: 首页 > article >正文

JVM - 垃圾回收器常见问题

本文主要讨论 ParNew,CMS,G1垃圾回收器

  • 常用的垃圾回收器有哪些?(直接给出答案就行,等提问具体的回收器)
  • CMS垃圾回收器介绍一下
  • G1回收器了解吗?介绍一下
  • G1和CMS有啥区别?
  • STW 了解吗?CMS 什么时候会 STW ?为什么要 STW ?

1. 常用的垃圾回收器有哪些?

对于年轻代,有 serial,ParNew

对于老年代,有 serial Old,CMS

还有 G1,能同时回收年轻代和老年代中的垃圾

2. CMS 垃圾回收器介绍一下

CMS 垃圾回收器是处理老年代区域的

CMS采用的是标记-清理算法,原理其实很简单,就是先通过追踪 GC Roots,看看各个对象是否被引用了,如果是的话,就标记存活对象,否则就是垃圾对象,然后一次性把垃圾回收对象都回收掉。这种方法最大的问题,就是会照成很多的内存碎片

垃圾回收时,会先把其他工作进程给停止,也就是 “Stop the World”。为了避免 STW 导致系统卡死时间过长,CMS 垃圾回收器采取的是垃圾回收线程和系统工作线程尽量同时执行的模型来处理的

CMS 在执行一次垃圾回收时,一般分为以下四个阶段

  • 初始标记
  • 并发标记
  • 重新标记
  • 并发清理

初始标记,会先 STW,把其他工作线程先停掉,然后查看对象是否被 GC Roots 直接引用,有就标记

并发标记,这个过程不会 STW,而是垃圾回收线程和其他线程一起并发执行。这个过程,就会不断产生新的对象,许多对象也会失去引用。垃圾回收线程会尽可能地对已有的对象进行 GC Roots追踪

接着进行到重新标记阶段,因为第二阶段又产生了许多新对象,所以这个阶段要继续让其他工作线程停下来,然后重新标记下第二阶段新创建的对象,还有一些已有对象可能失去引用变成垃圾的情况

最后是并发清理,这个阶段,让系统随意运行,然后他来清理掉之前的垃圾对象

3. G1回收器了解吗?介绍一下

因为垃圾回收器执行垃圾回收器会发生 “Stop the World” 情况,所以后续在对垃圾回收器进行优化时,就是围绕着减少 STW 情况出发

G1 垃圾回收器,将堆内存分为许多个 Region 块,最多有 2048个,每块 Region 块的大小必须是 2 的倍数,例如 1MB,2MB。其中还有新生代和老年代的概念,不过是逻辑上划分的,本质都是 Region块。新生代进入老年代的时机和其他垃圾回收器差不多。

G1 垃圾回收器最大的特点,是可以由开发者自己规定 STW 停留时间这个机制是怎么做到的呢?原因在于,G1 垃圾回收器会追踪每个 Region 块的回收价值,即每块 Region 区域中有多少垃圾对象,回收需要多少时间。通过这些信息,就能做到自定义 STW 预停时间了0

4. G1 和 CMS 有啥区别

首先 G1 回收器的内存结构完全区别于 CMS。G1 整体上是基于 ”标记-整理” 算法的实现,不会出现内存碎片,而 CMS 本质上是基于 “标记-清除” 算法实现,会有内存碎片问题。除此之外,G1 回收器可以根据自定义停顿时间模型,来决定本次回收多少 Region

5. STW了解吗?CMS什么时候会STW?为什么要 STW ?

STW 就是当垃圾回收线程工作时,会先停止其他功能线程

CMS在初始标记和重新标记阶段会 STW

如果垃圾回收的时候,其他应用线程也在进行,可能回导致数据不一致,比如刚把一个垃圾回收掉了,而后面突然又引用到了,引用内存回收错误


诚恳欢迎大家提出意见

......(待续未完


http://www.kler.cn/a/614318.html

相关文章:

  • 下一代数据工程:实时智能数据网格(Real-Time Data Mesh)
  • 【有外界干扰的BFS】经典题P2895Meteor Shower S
  • AI大模型、机器学习以及AI Agent开源社区和博客
  • [代码随想录] KMP 算法 28. 找出字符串中第一个匹配项的下标 459. 重复的子字符串
  • mac安装mongoDB的正确姿势
  • 智网安全:守护未来数字文明的基石
  • Vue3 配合 fullPage.js 打造高效全屏滚动网页
  • spring security认证流程分析
  • 对内核fork进程中写时复制的理解记录
  • 【Linux笔记】进程间通信——匿名管道||进程池
  • 智能仪表板DevExpress Dashboard v24.2新版亮点:支持.NET 9
  • 管理Visual Studio配置文件(使用Azure DevOps开发,免费GIT托管)
  • OpenAI API - 快速入门开发
  • 使用Python的pytesseract进行网站模拟登录的脚本,主要针对古诗文网(gushiwen.cn)的登录功能。
  • 图论问题集合
  • 加载MiniLM-L12-v2模型及知识库,调用Deepseek进行问答
  • 【Hysteria】部署+测试
  • 虚拟机docker配置ES
  • Docker:ERROR [internal] load metadata for docker.io/library/java:8-alpine问题解决
  • UDS故障码(DTC)SAE格式和HEX相互转换公式