【大白话说Java面试题 第55题】【JVM篇】第15题:JVM有哪些垃圾收集算法?

📌 PDF :大白话说Java面试题 --- 02-JVM篇

第15题:JVM有哪些垃圾收集算法

📚 回答:

  • 核心概念
    JVM 的垃圾收集算法是垃圾回收的核心机制,决定了如何高效地标记和回收内存中的垃圾对象。常见的垃圾收集算法包括以下三种:标记-复制标记-清除标记-整理

1. 标记-复制(Mark-Copy)算法
  • 定义

    • 将内存划分为两块区域(From 和 To),每次只使用其中一块。
    • 当一块区域的内存用完后,垃圾回收器会将存活对象复制到另一块区域,然后一次性清理掉已使用的空间。
  • 优点

    • 高效清理短生命周期的对象,避免内存碎片化问题。
  • 缺点

    • 需要额外的内存空间,导致内存利用率较低(通常只有 50%)。

    💡 适用场景

  • 年轻代中对象大多数是短生命周期的,适合使用标记-复制算法。


2. 标记-清除(Mark-Sweep)算法
  • 定义

    • 先标记所有存活对象,然后统一回收未标记的对象(即垃圾对象)。
  • 优点

    • 实现简单,适合一次性清理大量垃圾对象。
  • 缺点

    • 容易产生内存碎片,影响后续分配大对象的效率。

    💡 源码解析
    Serial OldParallel Old 收集器在老年代中使用了标记-整理算法,但基础原理与标记-清除类似。


3. 标记-整理(Mark-Compact)算法
  • 定义

    • 标记过程与标记-清除相同,不同的是标记完成后不会直接回收垃圾对象,而是将所有存活对象向一端移动,然后清理掉边界以外的空间。
  • 优点

    • 避免内存碎片化问题,适合频繁分配大对象的场景。
  • 缺点

    • 整理过程需要额外的时间开销,性能略低于标记-清除。

4. 总结对比
算法 适用场景 优点 缺点
标记-复制 年轻代(短生命周期对象) 高效清理垃圾,无内存碎片 需要额外的 Survivor 区,内存利用率低
标记-清除 老年代(少量垃圾对象) 实现简单,适合一次性清理大量垃圾 易产生内存碎片
标记-整理 老年代(频繁分配大对象) 避免内存碎片,适合长期运行的应用 整理过程耗时较长

💡 面试官视角

  • 面试官可能会问"为什么年轻代使用标记-复制算法?"答:因为年轻代中大多数对象是短生命周期的,标记-复制算法能高效清理垃圾且无碎片问题。
  • 面试官可能会追问"标记-清除和标记-整理的区别是什么?"答:标记-清除直接回收垃圾,容易产生碎片;标记-整理会压缩内存,避免碎片但耗时更长。
相关推荐
摇滚侠1 小时前
Java 基础面试题 真正的 offer 偏方 Java 基础 Java 高级
java·开发语言
蚰蜒螟1 小时前
深入剖析 OpenJDK 17 解释器中的安全点(Safepoint)进入与退出机制
java·开发语言·安全
Generalzy1 小时前
为什么 Go 的注释,能控制编译器?
java·python·golang
Galsk1 小时前
Linux零拷贝
java·linux·服务器·面试
李剑一1 小时前
华为二面稳了!面试官:请详细说明一下前端性能指标(FCP/LCP/CLS/TTI/TBT),如何采集、解读与优化?
前端·面试
Lucky_ldy1 小时前
C语言学习: 自定义类型—联合和枚举
c语言·学习·算法
gumichef1 小时前
栈和队列(2)
数据结构·算法·链表
m0_609160491 小时前
Go语言Beego框架如何用_Go语言Beego框架入门教程【高效】
jvm·数据库·python
进击的荆棘1 小时前
递归、搜索与回溯——综合(下)
c++·算法·leetcode·深度优先·dfs