网易三面:Java中默认使用的垃圾回收器及特点分版本说说?

文章内容收录到个人网站,方便阅读hardyfish.top/

JDK 7(以及之前)

  • 默认垃圾回收器
    • 新生代Parallel Scavenge(吞吐量优先收集器)
    • 老年代Parallel Old
  • 特点
    • 并行 GC:多线程回收新生代和老年代,适合批处理、后台任务等吞吐量优先场景。
    • STW(Stop-The-World)时间相对较长。
    • 调优主要依赖 -XX:MaxGCPauseMillis-XX:GCTimeRatio

JDK 8

  • 默认垃圾回收器Parallel GC(新生代 Parallel Scavenge + 老年代 Parallel Old)。
  • 特点
    • 吞吐量优先。
    • 新生代复制算法、老年代标记-整理算法。
    • 适合大内存、批量任务,不适合对延迟非常敏感的服务。
  • 备注
    • JDK 8 中 G1 GC 是可选(-XX:+UseG1GC),但不是默认。
    • 元空间(Metaspace)替代了永久代(PermGen)。

JDK 9 ~ JDK 10

  • 默认垃圾回收器G1 GC(Garbage First)
  • 特点
    • 面向低延迟:将堆划分为多个 Region,按优先级回收。
    • 可以预测停顿时间(-XX:MaxGCPauseMillis)。
    • 混合回收(Mixed GC):一次回收新生代 + 部分老年代。
    • 减少了全堆 STW 的次数,但调优复杂度比 Parallel GC 高。

JDK 11 ~ JDK 16

  • 默认垃圾回收器 :依旧是 G1 GC
  • 特点更新
    • JDK 11:G1 增加并行 Full GC,减少单线程 Full GC 带来的长时间停顿。
    • JDK 12:G1 支持 abortable mixed collections(可中断混合回收)。
    • JDK 14:移除 CMS(Concurrent Mark-Sweep)GC。
    • 调优建议:尽量通过 -XX:MaxGCPauseMillis 控制延迟,不盲目调 Region 数量。

JDK 17 ~ 现在

  • 默认垃圾回收器G1 GC(依旧默认)
  • 特点更新
    • 继续优化停顿预测。
    • 并行化更多阶段。
    • 提供更多可选低延迟 GC:
      • ZGC-XX:+UseZGC):毫秒级停顿,支持超大堆(TB 级)。
      • Shenandoah-XX:+UseShenandoahGC):低延迟,停顿时间与堆大小无关。
  • 趋势:低延迟场景逐渐用 ZGC / Shenandoah,G1 作为通用型默认。

汇总表

JDK 版本 默认 GC 特点
7 及以前 Parallel Scavenge + Parallel Old 吞吐量优先,STW 时间长
8 Parallel GC 吞吐量优先,可选 G1
9 ~ 10 G1 GC 低延迟,分 Region 回收
11 ~ 16 G1 GC G1 优化更多并行、可预测停顿
17+ G1 GC 默认 G1,可选 ZGC/Shenandoah 实现极低延迟
相关推荐
uzong3 分钟前
Skill 被广泛应用,到底什么是 Skill,今天详细介绍一下
人工智能·后端·面试
小码哥_常16 分钟前
Kafka平替!SpringBoot+Redis Stream+消费组打造极致消息队列
后端
发现一只大呆瓜30 分钟前
React-路由监听 / 跳转 / 守卫全攻略(附实战代码)
前端·react.js·面试
IT_陈寒2 小时前
Redis缓存击穿:3个鲜为人知的防御策略,90%开发者都忽略了!
前端·人工智能·后端
uzong2 小时前
Harness Engineering 是什么?一场新的 AI 范式已经开始
人工智能·后端·架构
左左右右左右摇晃3 小时前
Java并发——synchronized锁
java·开发语言
唐叔在学习3 小时前
Python桌面端应用最小化托盘开发实践
后端·python·程序员
消失的旧时光-19433 小时前
Android 面试高频:JSON 文件、大数据存储与断电安全(从原理到工程实践)
android·面试·json
yuhaiqiang3 小时前
被 AI 忽悠后,开始怀念搜索引擎了?
前端·后端·面试
li星野4 小时前
[特殊字符] Linux/嵌入式Linux面试模拟卷
linux·运维·面试