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

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


诚恳欢迎大家提出意见

......(待续未完

相关推荐
Lee川37 分钟前
优雅进化的JavaScript:从ES6+新特性看现代前端开发范式
javascript·面试
初次攀爬者38 分钟前
RocketMQ在Spring Boot上的基础使用
java·spring boot·rocketmq
花花无缺42 分钟前
搞懂@Autowired 与@Resuorce
java·spring boot·后端
Derek_Smart2 小时前
从一次 OOM 事故说起:打造生产级的 JVM 健康检查组件
java·jvm·spring boot
NE_STOP3 小时前
MyBatis-mybatis入门与增删改查
java
Lee川4 小时前
从异步迷雾到优雅流程:JavaScript异步编程与内存管理的现代化之旅
javascript·面试
晴殇i6 小时前
揭秘JavaScript中那些“不冒泡”的DOM事件
前端·javascript·面试
孟陬6 小时前
国外技术周刊 #1:Paul Graham 重新分享最受欢迎的文章《创作者的品味》、本周被划线最多 YouTube《如何在 19 分钟内学会 AI》、为何我不
java·前端·后端
想用offer打牌6 小时前
一站式了解四种限流算法
java·后端·go
绝无仅有6 小时前
Redis过期删除与内存淘汰策略详解
后端·面试·架构