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:对所有对象使用标记整理
相关推荐
唐不是营养物质18 分钟前
Apache POI 的 HSSFWorkbook、SXSSFWorkbook和XSSFWorkbook三者的区别
java
樽酒ﻬق1 小时前
Prometheus Operator:Kubernetes 监控自动化实践
java·算法·云原生·运维开发
有梦想的攻城狮1 小时前
快速搭建Maven仓库服务
java·maven·仓库·nexus
面朝大海,春不暖,花不开1 小时前
Java进程API详解
java·开发语言·python
Lyinj1 小时前
jdk1.8 nio相关。java对象和epoll三大函数怎么关联的?(有点乱有点跳)
java·python·nio
青云交1 小时前
Java 大视界 -- Java 大数据在智能教育学习资源智能分类与标签优化中的应用(346)
java·大数据·智能教育·资源分类·标签优化·特殊教育·课标匹配
灰小猿1 小时前
多级@JsonTypeInfo和@JsonSubTypes注解使用详解及场景分析
java·后端·mysql·spring·spring cloud
丁一郎学编程1 小时前
多线程的区别和联系
java·开发语言·jvm
lifallen1 小时前
Flink Exactly Once 和 幂等
java·大数据·数据结构·数据库·分布式·flink
哪里不会点哪里.1 小时前
单例模式:确保全局唯一实例
java·开发语言·单例模式