1️⃣ JVM 堆结构回顾
在 HotSpot JVM 的分代内存模型中,堆大致分为:
新生代(Young Generation)
Eden 区
Survivor 区(From/To)
老年代(Old Generation)
方法区 / 元空间(Metaspace)
👉 GC 的不同类型主要是针对这些区域。
2️⃣ Minor GC
触发条件:Eden 区满时触发。
回收范围:新生代(Eden + Survivor)。
特点:
发生频率高(因为对象朝生夕死,Eden 很快满)。
速度快(复制算法 + 新生代对象存活率低)。
不会影响老年代。
流程(复制算法):
存活对象从 Eden + From Survivor 复制到 To Survivor。
Survivor 区不够时,部分对象晋升到老年代。
3️⃣ Major GC(Old GC)
触发条件:
老年代满时触发。
Survivor 区对象晋升失败(老年代空间不足)。
回收范围:老年代。
特点:
发生频率低(老年代对象存活时间长)。
回收速度慢(老年代对象多,使用 标记-清除 / 标记-整理)。
可能会伴随一次 Minor GC(因为要腾出 Survivor 的空间)。
4️⃣ Full GC
触发条件:
调用
System.gc()(只是建议,JVM 可忽略)。老年代空间不足。
方法区 / 元空间不足。
Minor GC 后晋升失败。
回收范围:整个堆(新生代 + 老年代)+ 方法区/元空间。
特点:
最彻底的 GC。
速度最慢,STW(Stop-The-World)时间长。
应该尽量避免频繁发生 Full GC。
5️⃣ 三者对比总结表
GC 类型 回收区域 触发条件 算法 速度 频率 Minor GC 新生代(Eden + Survivor) Eden 满 复制 快 高频 Major GC 老年代 老年代满 / 晋升失败 标记整理 慢 低频 Full GC 整个堆 + 方法区/元空间 System.gc() / 老年代不足 综合 最慢 尽量少
6️⃣ 小结
Minor GC:轻量、频繁、只回收新生代。
Major GC:主要清理老年代,速度比 Minor GC 慢。
Full GC:清理整个堆和方法区,最彻底但最耗时,应避免频繁发生。
⚡ 常见面试题:
👉 "Minor GC 和 Full GC 的区别是什么?"
Minor GC 只清理新生代,发生频繁且速度快;
Full GC 会清理整个堆和方法区,耗时长,应该尽量避免。
面试tips--JVM(4)--Minor GC & Major GC & Full GC
你我约定有三2025-09-03 9:09
相关推荐
2401_831419448 分钟前
Python分类汇总怎么做_Crosstab交叉表与多条件联合频数频率统计2301_787312439 分钟前
Go语言怎么用channel做信号通知_Go语言channel信号模式教程【完整】2301_8180084415 分钟前
如何删除ASM中的数据文件_ALTER DISKGROUP DROP FILE彻底清除2401_8987176629 分钟前
mysql如何进行全量数据库备份_mysqldump工具的使用技巧wuminyu31 分钟前
专家视角看Lambda表达式的原理解析m0_7485548135 分钟前
SQL注入的安全架构设计_将数据库置于内网隔离区许彰午1 小时前
CacheSQL:一个面向政务系统的内存缓存数据库中间件不会敲代码11 小时前
从 URL 到页面展示,还有哪些你忽略的底层细节?(DNS 与传输篇)iAm_Ike1 小时前
怎么关闭MongoDB不需要的HTTP管理接口及REST APIm0_741173331 小时前
CSS移动端实现卡片悬浮投影_利用box-shadow设置层次感