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

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


诚恳欢迎大家提出意见

......(待续未完

相关推荐
绝无仅有20 小时前
未来教育行业的 Go 服务开发解决方案与实践
后端·面试·github
A尘埃20 小时前
智能工单路由系统(Java)
java·开发语言·智能工单
失散1321 小时前
分布式专题——1.1 Redis单机、主从、哨兵、集群部署
java·数据库·redis·分布式·架构
刘一说21 小时前
Linux调试命令速查:Java/微服务必备
java·linux·微服务
IT·陈寒1 天前
怎么这么多 StringUtils —— Apache、Spring、Hutool 全面对比
java·spring·apache
UrbanJazzerati1 天前
掌握 xlwings 的 used_range:高效处理 Excel 数据区域
python·面试·excel
AAA修煤气灶刘哥1 天前
MySQL 查文本查哭了?来唠唠 ES 这货:从 “啥是 ES” 到 Java 撸代码,一篇整明白!
java·后端·elasticsearch
金銀銅鐵1 天前
[Java] 浅析密封类(Sealed Classes) 在 class 文件中是如何实现的
java·后端
Hello.Reader1 天前
一文通关 Proto3完整语法与工程实践
java·linux·数据库·proto3
DashingGuy1 天前
算法(keep learning)
java·数据结构·算法