JVM 的垃圾回收器

新生代回收器

通性
  • 会触发StW,暂停所有应用线程
  • 复制算法
Serial
  • 单线程回收
  • 适合单线程系统
ParNew
  • 多线程回收
  • 优先保证响应速度,降低 STW(STW 越大,执行垃圾回收的时间越长,回收的垃圾越多,减少垃圾回收的频率)
  • 适合低延迟系统,搭配 CMS 使用
Parallel Scavenge
  • 多线程回收
  • 支持自适应策略,自动调节堆分区的大小和晋升年龄,优先保障吞吐量
  • 适合大规模密集型任务等吞吐量较高的场景

老年代回收器

Serial Old
  • 单线程
  • 标记整理
  • 配合 Serial 使用
CMS
  • 多线程
  • 标记清除
    • 初始标记:暂停用户线程,标记GC Roots对象直接关联的对象
    • 并发标记:并发标记所有垃圾对象
    • 重新标记:对并发标记时产生的错标、漏标,重新标记
    • 并发清理:并发删除垃圾对象
  • 配合 ParNew 使用
Parallel Old
  • 多线程
  • 标记整理
  • 配合 Parallel Scavenge 使用
G1
  • 将内存分为多个大小相等的 Region 区域,通过堆空间 /2048 得到
  • Young GC:将 Eden 和 Survivor 中存活对象复制到新 Survivor 中,年龄 +1,清空这些区域
  • Humongous 区:对象大小超过 region 的一半,直接放入老年代的 Humongous 区
  • Mixed GC:新生代全部+老年代存活度低的区域回收,新生代转移到一个区,老年代转移到一个区
    • 初始标记、并发标记、最终标记
    • 筛选回收:对各个region的回收价值和成本排序,根据用户期望停顿时间和回收计划,选择 region 回收
  • Full GC:对所有对象使用标记整理
相关推荐
2401_833197736 分钟前
更优雅的测试:Pytest框架入门
jvm·数据库·python
后端AI实验室7 分钟前
等保三级整改,敏感数据加密,数十个系统——3个人用Cursor一周搞定了
java·ai
qq_334060219 分钟前
spring_springmvc_mybatis权限控制+boostrap实现UI
java·spring·mybatis
sunwenjian88615 分钟前
Spring Boot 整合 Druid 并开启监控
java·spring boot·后端
1104.北光c°20 分钟前
基于Canal + Kafka的高可用关注系统:一主多从关系链
java·开发语言·笔记·分布式·程序人生·kafka·一主多从
2501_9249526921 分钟前
Python深度学习入门:TensorFlow 2.0/Keras实战
jvm·数据库·python
Mem0rin22 分钟前
[Java]异常及其处理
java·开发语言
skiy22 分钟前
Spring boot创建时常用的依赖
java·spring boot·后端
2401_8914821723 分钟前
Python多线程与多进程:如何选择?(GIL全局解释器锁详解)
jvm·数据库·python
2401_8512729924 分钟前
用Python实现自动化的Web测试(Selenium)
jvm·数据库·python