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

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


诚恳欢迎大家提出意见

......(待续未完

相关推荐
阿维的博客日记24 分钟前
Nacos 为什么能让配置动态生效?(涉及 @RefreshScope 注解)
java·spring
雨辰AI25 分钟前
SpringBoot3 + 人大金仓读写分离 + 分库分表 + 集群高可用 全栈实战
java·数据库·mysql·政务
Patrick_Wilson1 小时前
知识沉淀的四层模型:从个人笔记到企业资产,让文档真正长出复利
面试·程序员·ai编程
辰海Coding2 小时前
MiniSpring框架学习-完成的 IoC 容器
java·spring boot·学习·架构
橙序员小站2 小时前
人人都在鼓吹的OPC,我想给你泼盆冷水
面试·创业
小小编程路2 小时前
C++ 多线程与并发
java·jvm·c++
AI视觉网奇2 小时前
linux 检索库 判断库是否支持
java·linux·服务器
她的男孩2 小时前
从零搭一个企业后台,为什么我把能力拆成 Starter 和 Plugin
java·后端·架构
RainCity2 小时前
Java Swing 自定义组件库分享(七)
java·笔记·后端
Sam_Deep_Thinking3 小时前
连锁门店的外卖订单平台对接
java·微服务·架构·系统架构