0

0

Java面试之JVM垃圾回收算法汇总

煙雲

煙雲

发布时间:2026-02-07 08:01:29

|

729人浏览过

|

来源于php中文网

原创

JVM垃圾回收算法考察重点是实际应用场景与设计原理:CMS为低延迟用标记-清除而非标记-整理以避免STW;G1通过Region分区和RSet实现混合回收;ZGC与Shenandoah借助读屏障和指针着色/转发实现并发整理。

java面试之jvm垃圾回收算法汇总

Java面试中问到JVM垃圾回收算法,不是让你背诵“标记-清除”“复制”“标记-整理”这些名词,而是看你能不能说清:每种算法在什么内存区域、什么场景下被实际使用,以及为什么选它而不是别的。HotSpot虚拟机的GC实现和理论算法之间存在关键差异——比如“复制算法”在新生代用的是 Survivor 区的两个半区(S0S1),但实际触发条件、晋升阈值、动态年龄判定等细节,才是面试官真正想确认你是否真懂的地方。

为什么CMS不使用标记-整理算法?

CMS(Concurrent Mark-Sweep)的目标是尽可能减少停顿时间,适用于老年代。它采用的是标记-清除算法,而非标记-整理,原因很实际:

  • 标记-整理 需要移动存活对象,意味着必须暂停所有应用线程(STW),违背CMS低延迟的设计初衷
  • 标记-清除 虽然会产生内存碎片,但CMS通过预留 ConcGCThreads 并发清理,且配合 UseCMSCompactAtFullCollection(已废弃)或 CMSScavengeBeforeRemark 缓解问题
  • 一旦碎片过多触发 Concurrent Mode Failure,JVM会退化为 Serial Old 进行 Full GC —— 此时才真正执行标记-整理,但代价是长时间STW

G1的Region分区如何改变传统算法边界?

G1不再严格区分年轻代/老年代的连续内存空间,而是把堆划分为多个固定大小的 Region(默认 1~32MB)。它的回收逻辑融合了多种策略:

  • 年轻代回收(Young GC)本质是复制算法:从所有 Eden Region + 部分 Survivor Region 复制存活对象到新的 SurvivorOld Region
  • 混合回收(Mixed GC)则按 G1HeapRegionSizeG1MixedGCCountTarget 动态选择一批 Old Region,对其中的存活对象执行复制(类似复制算法),同时合并空闲 Region
  • 它不追求“一次清理整个老年代”,而是基于 Remembered Set(RSet) 快速识别跨 Region 引用,避免全堆扫描 —— 这才是 G1 降低 STW 的核心技术,不是算法本身多先进

ZGC 和 Shenandoah 的“并发整理”怎么绕过传统限制?

ZGC 和 Shenandoah 都宣称“几乎不 STW”,核心突破点不在算法名称,而在内存访问层面的改造:

FashionLabs
FashionLabs

AI服装模特、商品图,可商用,低价提升销量神器

下载

立即学习Java免费学习笔记(深入)”;

  • 它们都使用 读屏障(Load Barrier) 拦截对象引用访问,在对象被移动时同步更新引用,使得应用线程可与 GC 线程并发执行整理
  • ZGC 采用着色指针(colored pointers),将元数据直接编码在 64 位地址的高几位;Shenandoah 则依赖 Brooks Pointer(在对象头前加转发指针)
  • 两者都不再需要“Stop-The-World 整理阶段”,但初始标记和最终标记仍有极短 STW(通常
  • 注意:-XX:+UseZGC 要求 JDK 11+(生产就绪在 JDK 15+),而 Shenandoah 在 JDK 12+ 作为实验特性引入,JDK 15+ 默认启用
// 示例:JDK 17 启用 ZGC 的典型启动参数
java -XX:+UseZGC -Xmx8g -Xlog:gc*:file=gc.log:time -jar app.jar

真正容易被忽略的是:算法选择永远服务于 GC 目标(吞吐量 / 延迟 / 内存占用),而目标又受限于硬件(如大内存机器上 CMS 容易失败)、应用特征(如大量短期对象 vs 长期缓存对象)、甚至 JDK 版本(JDK 8 默认是 Parallel GC,JDK 11+ 默认是 G1)。死记硬背算法流程不如搞懂 HotSpot 中 CollectedHeap 子类(GenCollectedHeapG1CollectedHeapZCollectedHeap)各自如何调度回收行为。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

404

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

584

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

613

2023.08.10

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

431

2023.08.14

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

65

2026.02.06

java多线程方法汇总
java多线程方法汇总

本专题整合了java多线程面试题、实现函数、执行并发相关内容,阅读专题下面的文章了解更多详细内容。

32

2026.02.06

1688阿里巴巴货源平台入口与批发采购指南
1688阿里巴巴货源平台入口与批发采购指南

本专题整理了1688阿里巴巴批发进货平台的最新入口地址与在线采购指南,帮助用户快速找到官方网站入口,了解如何进行批发采购、货源选择以及厂家直销等功能,提升采购效率与平台使用体验。

488

2026.02.06

快手网页版入口与电脑端使用指南 快手官方短视频观看入口
快手网页版入口与电脑端使用指南 快手官方短视频观看入口

本专题汇总了快手网页版的最新入口地址和电脑版使用方法,详细提供快手官网直接访问链接、网页端操作教程,以及如何无需下载安装直接观看短视频的方式,帮助用户轻松浏览和观看快手短视频内容。

265

2026.02.06

C# 多线程与异步编程
C# 多线程与异步编程

本专题深入讲解 C# 中多线程与异步编程的核心概念与实战技巧,包括线程池管理、Task 类的使用、async/await 异步编程模式、并发控制与线程同步、死锁与竞态条件的解决方案。通过实际项目,帮助开发者掌握 如何在 C# 中构建高并发、低延迟的异步系统,提升应用性能和响应速度。

18

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3.3万人学习

C# 教程
C# 教程

共94课时 | 8.9万人学习

Java 教程
Java 教程

共578课时 | 60.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号