jvm垃圾回收算法

垃圾回收(Garbage Collection,GC)是自动内存管理的一种形式,用于自动释放不再使用的内存空间。不同的编程语言和运行环境可能会使用不同的垃圾回收算法。以下是一些常见的垃圾回收算法:

  1. 标记-清除(Mark-Sweep)算法

    • 标记阶段:遍历所有的根对象,标记所有从根对象可达的对象。
    • 清除阶段:遍历整个堆,清除所有未被标记的对象。
  2. 标记-整理(Mark-Compact)算法

    • 类似于标记-清除算法,但在标记完存活的对象后,会将这些对象移动到堆的一端,然后清理边界外的所有空间。这样可以避免内存碎片问题。
  3. 复制(Copying)算法

    • 将内存分为两个半区,每次只使用其中一半。当这一半内存使用完时,就将存活的对象复制到另一半区域,然后清理已使用过的那半区域。
  4. 增量(Incremental)垃圾回收

    • 将垃圾回收分成更小的步骤,分多次执行,以减少应用程序的暂停时间。
  5. 分代(Generational)垃圾回收

    • 基于这样一个假设:新创建的对象大部分会很快被回收,而存活下来的对象往往会活得更久。因此,将堆分为新生代和老年代,新生代的对象存活率低,使用复制算法;老年代的对象存活率高,使用标记-清除或标记-整理算法。
  6. 并行垃圾回收

    • 使用多线程来执行垃圾回收任务,以提高垃圾回收的效率。
  7. 并发垃圾回收

    • 垃圾回收线程与应用程序线程同时运行,以减少应用程序的暂停时间。
  8. 停止-复制(Stop-The-World, STW)

    • 在垃圾回收期间,暂停应用程序的所有线程,直到垃圾回收完成。这是最简单的垃圾回收策略,但对用户体验影响较大。
  9. 垃圾回收器(Garbage Collectors)

    • Serial GC:单线程的垃圾回收器,适用于单核处理器。
    • Parallel GC:多线程的垃圾回收器,是Serial GC的多线程版本。
    • CMS(Concurrent Mark Sweep):并发标记-清除垃圾回收器,尽量减少应用程序的暂停时间。
    • G1(Garbage-First):一种服务器端的垃圾回收器,旨在替换CMS GC,可以预测停顿时间,并且可以处理更大的堆。
    • ZGC(Z Garbage Collector):可扩展的低延迟垃圾回收器,可以处理数TB的堆内存。

每种垃圾回收算法都有其优缺点,适用于不同的场景和需求。垃圾回收器的设计者需要根据实际应用的特点和性能要求来选择或设计合适的垃圾回收算法。

相关推荐
zh1570233 分钟前
JavaScript中WorkerThreads解决服务端计算瓶颈
jvm·数据库·python
代码AI弗森7 分钟前
一文理清楚“算力申请 / 成本测算 / 并发评估”
java·服务器·数据库
Old Uncle Tom26 分钟前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆36 分钟前
洛谷题单入门1 顺序结构
数据结构·算法·golang
小小小米粒38 分钟前
Collection单列集合、Map(Key - Value)双列集合,多继承实现。
java·开发语言·windows
生信碱移38 分钟前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业1 小时前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
摇滚侠1 小时前
expdp 查看帮助
java·数据库·oracle
2401_871492851 小时前
Vue.js监听器watch利用回调函数处理级联下拉框数据联动
jvm·数据库·python
:1212 小时前
java基础
java·开发语言