JAVA面试-JVM篇 02-G1垃圾收集器的工作原理是什么与CMS的区别

G1垃圾收集器工作原理与CMS区别

一、文章概述

G1(Garbage-First)是JDK9默认的垃圾收集器,全面取代CMS。它打破了传统分代收集的物理限制,采用Region分区设计,兼顾吞吐量与低延迟,支持用户设置最大停顿时间。本文讲解G1核心工作原理,并通过表格对比其与CMS的关键差异。

二、G1核心工作原理

G1将整个Java堆划分为多个大小相等的Region (默认2048个),每个Region可动态作为Eden、Survivor、老年代或大对象区(Humongous)。其核心思想是优先回收垃圾最多的Region,在有限时间内获得最高回收效率。

G1核心收集流程(STW阶段已加粗)

#mermaid-svg-G281qQnPVdNeigKm{font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}@keyframes edge-animation-frame{from{stroke-dashoffset:0;}}@keyframes dash{to{stroke-dashoffset:0;}}#mermaid-svg-G281qQnPVdNeigKm .edge-animation-slow{stroke-dasharray:9,5!important;stroke-dashoffset:900;animation:dash 50s linear infinite;stroke-linecap:round;}#mermaid-svg-G281qQnPVdNeigKm .edge-animation-fast{stroke-dasharray:9,5!important;stroke-dashoffset:900;animation:dash 20s linear infinite;stroke-linecap:round;}#mermaid-svg-G281qQnPVdNeigKm .error-icon{fill:#552222;}#mermaid-svg-G281qQnPVdNeigKm .error-text{fill:#552222;stroke:#552222;}#mermaid-svg-G281qQnPVdNeigKm .edge-thickness-normal{stroke-width:1px;}#mermaid-svg-G281qQnPVdNeigKm .edge-thickness-thick{stroke-width:3.5px;}#mermaid-svg-G281qQnPVdNeigKm .edge-pattern-solid{stroke-dasharray:0;}#mermaid-svg-G281qQnPVdNeigKm .edge-thickness-invisible{stroke-width:0;fill:none;}#mermaid-svg-G281qQnPVdNeigKm .edge-pattern-dashed{stroke-dasharray:3;}#mermaid-svg-G281qQnPVdNeigKm .edge-pattern-dotted{stroke-dasharray:2;}#mermaid-svg-G281qQnPVdNeigKm .marker{fill:#333333;stroke:#333333;}#mermaid-svg-G281qQnPVdNeigKm .marker.cross{stroke:#333333;}#mermaid-svg-G281qQnPVdNeigKm svg{font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;}#mermaid-svg-G281qQnPVdNeigKm p{margin:0;}#mermaid-svg-G281qQnPVdNeigKm .label{font-family:"trebuchet ms",verdana,arial,sans-serif;color:#333;}#mermaid-svg-G281qQnPVdNeigKm .cluster-label text{fill:#333;}#mermaid-svg-G281qQnPVdNeigKm .cluster-label span{color:#333;}#mermaid-svg-G281qQnPVdNeigKm .cluster-label span p{background-color:transparent;}#mermaid-svg-G281qQnPVdNeigKm .label text,#mermaid-svg-G281qQnPVdNeigKm span{fill:#333;color:#333;}#mermaid-svg-G281qQnPVdNeigKm .node rect,#mermaid-svg-G281qQnPVdNeigKm .node circle,#mermaid-svg-G281qQnPVdNeigKm .node ellipse,#mermaid-svg-G281qQnPVdNeigKm .node polygon,#mermaid-svg-G281qQnPVdNeigKm .node path{fill:#ECECFF;stroke:#9370DB;stroke-width:1px;}#mermaid-svg-G281qQnPVdNeigKm .rough-node .label text,#mermaid-svg-G281qQnPVdNeigKm .node .label text,#mermaid-svg-G281qQnPVdNeigKm .image-shape .label,#mermaid-svg-G281qQnPVdNeigKm .icon-shape .label{text-anchor:middle;}#mermaid-svg-G281qQnPVdNeigKm .node .katex path{fill:#000;stroke:#000;stroke-width:1px;}#mermaid-svg-G281qQnPVdNeigKm .rough-node .label,#mermaid-svg-G281qQnPVdNeigKm .node .label,#mermaid-svg-G281qQnPVdNeigKm .image-shape .label,#mermaid-svg-G281qQnPVdNeigKm .icon-shape .label{text-align:center;}#mermaid-svg-G281qQnPVdNeigKm .node.clickable{cursor:pointer;}#mermaid-svg-G281qQnPVdNeigKm .root .anchor path{fill:#333333!important;stroke-width:0;stroke:#333333;}#mermaid-svg-G281qQnPVdNeigKm .arrowheadPath{fill:#333333;}#mermaid-svg-G281qQnPVdNeigKm .edgePath .path{stroke:#333333;stroke-width:2.0px;}#mermaid-svg-G281qQnPVdNeigKm .flowchart-link{stroke:#333333;fill:none;}#mermaid-svg-G281qQnPVdNeigKm .edgeLabel{background-color:rgba(232,232,232, 0.8);text-align:center;}#mermaid-svg-G281qQnPVdNeigKm .edgeLabel p{background-color:rgba(232,232,232, 0.8);}#mermaid-svg-G281qQnPVdNeigKm .edgeLabel rect{opacity:0.5;background-color:rgba(232,232,232, 0.8);fill:rgba(232,232,232, 0.8);}#mermaid-svg-G281qQnPVdNeigKm .labelBkg{background-color:rgba(232, 232, 232, 0.5);}#mermaid-svg-G281qQnPVdNeigKm .cluster rect{fill:#ffffde;stroke:#aaaa33;stroke-width:1px;}#mermaid-svg-G281qQnPVdNeigKm .cluster text{fill:#333;}#mermaid-svg-G281qQnPVdNeigKm .cluster span{color:#333;}#mermaid-svg-G281qQnPVdNeigKm div.mermaidTooltip{position:absolute;text-align:center;max-width:200px;padding:2px;font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:12px;background:hsl(80, 100%, 96.2745098039%);border:1px solid #aaaa33;border-radius:2px;pointer-events:none;z-index:100;}#mermaid-svg-G281qQnPVdNeigKm .flowchartTitleText{text-anchor:middle;font-size:18px;fill:#333;}#mermaid-svg-G281qQnPVdNeigKm rect.text{fill:none;stroke-width:0;}#mermaid-svg-G281qQnPVdNeigKm .icon-shape,#mermaid-svg-G281qQnPVdNeigKm .image-shape{background-color:rgba(232,232,232, 0.8);text-align:center;}#mermaid-svg-G281qQnPVdNeigKm .icon-shape p,#mermaid-svg-G281qQnPVdNeigKm .image-shape p{background-color:rgba(232,232,232, 0.8);padding:2px;}#mermaid-svg-G281qQnPVdNeigKm .icon-shape .label rect,#mermaid-svg-G281qQnPVdNeigKm .image-shape .label rect{opacity:0.5;background-color:rgba(232,232,232, 0.8);fill:rgba(232,232,232, 0.8);}#mermaid-svg-G281qQnPVdNeigKm .label-icon{display:inline-block;height:1em;overflow:visible;vertical-align:-0.125em;}#mermaid-svg-G281qQnPVdNeigKm .node .label-icon path{fill:currentColor;stroke:revert;stroke-width:revert;}#mermaid-svg-G281qQnPVdNeigKm :root{--mermaid-font-family:"trebuchet ms",verdana,arial,sans-serif;} **初始标记 STW**
并发标记
**最终标记 STW**
**筛选回收 STW**

阶段说明

  1. 初始标记:标记GC Roots直接关联对象,停顿极短
  2. 并发标记:与用户线程并行,遍历堆标记存活对象
  3. 最终标记:修正并发阶段的引用变动,短暂停顿
  4. 筛选回收:G1特有阶段,根据用户设置的停顿时间,优先回收垃圾最多的Region,采用复制算法整理内存

三、G1与CMS核心区别

对比维度 G1收集器 CMS收集器
底层结构 整堆Region分区 物理分代(年轻代+老年代)
收集范围 整堆收集 仅老年代收集
核心算法 标记-复制+标记-整理 标记-清除
内存碎片 无碎片(复制整理) 大量内存碎片
停顿控制 支持设置最大停顿时间 无法预测停顿时间
大对象处理 专门Humongous区 直接进入老年代
适用场景 大堆、低延迟、高吞吐量 中小堆、纯低延迟场景

总结

G1通过Region分区和优先回收策略,从根本上解决了CMS的内存碎片问题,实现了可预测的低延迟。它兼顾了吞吐量和响应时间,是现代JVM的首选收集器;而CMS作为经典的并发收集器,其设计思想为G1等新一代收集器奠定了基础。

相关推荐
ywl4708120871 小时前
spring单列bean之循环依赖核心源码解读
java·后端·spring
我命由我123451 小时前
RFID 技术极简理解
java·c语言·c++·嵌入式硬件·物联网·visualstudio·java-ee
格发许可优化管理系统1 小时前
Mentor许可证与其他软件许可证的深度比较
java·大数据·运维·c语言·c++·算法
pingglala1 小时前
winscp连接linux失败解决方法
java·linux·服务器
Javatutouhouduan1 小时前
深入学习JVM底层原理:源码剖析与实例详解!
java·jvm·java面试·后端开发·java程序员·java八股文·java性能优化
Flynt1 小时前
我把 JDK21 虚拟线程用成了"性能灾难",复盘完发现踩了三个大坑
java·ai编程
古希腊掌管代码的神THU2 小时前
解析 MiniMax M3 多模态大模型的架构/源码?
人工智能·深度学习·自然语言处理·面试
做一个快乐的小傻瓜2 小时前
ZYNQ DEV套件引脚约束
java·linux·运维
CoderYanger2 小时前
Java EE:6.网络编程套接字(第二弹)
java·网络·程序人生·面试·职场和发展·java-ee·学习方法