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

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


诚恳欢迎大家提出意见

......(待续未完

相关推荐
打野二师兄2 分钟前
Spring Boot 自动配置:从 2.x 到 3.x 的进化之路
java·spring boot·后端
SoulruiA25 分钟前
JVM 崩溃(Fatal Error)解决方法
jvm
Monkey-旭36 分钟前
Android JNI 语法全解析:从基础到实战
android·java·c++·c·jni·native
魑魅魍魉都是鬼1 小时前
随缘玩 一: 代理模式
android·java·代理模式
你我约定有三1 小时前
分布式微服务--RPC:原理、使用方式、与 HTTP/REST 的区别与选择
java·开发语言·分布式·后端·微服务·rpc
loop lee1 小时前
【JVM】常见的 Java 垃圾回收算法以及常见的垃圾回收器介绍及选型
java·jvm·算法
RainbowSea2 小时前
伙伴匹配系统(移动端 H5 网站(APP 风格)基于Spring Boot 后端 + Vue3 - 02
java·vue.js·spring boot
工业互联网专业2 小时前
基于JavaWeb的兼职发布平台的设计与实现
java·vue.js·spring boot·毕业设计·源码·课程设计·兼职发布平台
CLO_se_2 小时前
嵌软面试——ARM Cortex-M寄存器组
arm开发·面试·职场和发展
kk在加油2 小时前
JVM指令集
jvm