G1垃圾回收器

垃圾回收器发展史

G1最大的特征

将大空间分成若干小区域能实现一些更复杂、更精细的功能

G1与传统模型对比

G1由JDK7引入,Java8基本成熟,JDK9称为默认垃圾回收器,JDK14删除CMS,G1登基

划分成小区域的好处

  • 垃圾回收线程和工作线程能够并行工作,避免"STW
  • 不同区域可同时回收,并发性更高,更适合多核服务器
  • 可以先回收一部分区域,回收更快
  • 可以建立停顿预测模型,用户可以设定垃圾回收最长时间

G1对象管理

年轻代垃圾回收

Region划分原理

大对象分区(H区)

新生代与老年代占比

新生代大约占整个堆的1/3,老年代占比大约剩余的2/3

也有说新生代占堆比例是动态变化的最小5%,然后慢慢增加到60%

如何设置分区大小

-XX:G1HeapRegionSize=4M

此命令可以设置region区大小为4M,分区最大可以设置32M

G1三种垃圾回收策略的原理

  • 新生代回收原理
  • 混合回收原理
  • Ful回收原理
  • 大对象回收

新生代满了就会触发新生代回收,只回收新生代

前提新生代满了并且老年代占用达到阈值会触发混合回收,先执行新生代回收和再执行老年代回收

当混合回收后对象仍无法分配会触发Full GC

几个容易混淆的概念

YGC新生代回收的基本过程

YGC的基本过程一

标记存活对象:从GCroots出发标记存活对象

GCroots有哪些?

YGC的基本过程二

复制存活对象到S区,该过程最耗时

YGC的基本过程三

释放垃圾集合,回收region;该工作反而比较快,类似硬盘格式化。

YGC的基本过程四

YGC的基本过程五

堆空间使用超过45%

YGC里并行执行的任务

YGC里串行执行的任务

G1垃圾收集器停顿预测模型

G1收集器突出表现出来的一点是通过一个停顿预测模型根据用户配置的停顿时间来选择Cset的大小,从而达到用户期待的应用程序暂停时间

通过-XX:MaxGCPauseMillis参数来设置,这一点有点类似于Parallel Scavenge收集器.关于停顿时间的设置并不是越短越好

设置的时间越短意味着每次收集的Cset越小,导致垃圾逐步积累变多,最终不得不退化成Serial GC;

停顿时间设置的过长,那么会导致每次都会产生长时间的停顿,影响了程序对外的响应时间

G1的衰减预测模型

垃圾回收的时间花到哪里了?

真正决定回收时间的就是转移对象所需要的时间甚至可以直接简化为回收时间=对象转移时间

混合回收和后面的FUII回收都是同时处理新生代和老年代区域

对象什么时候进入老年代

混合回收什么时候发生?

通过参数可调整触发时机

混合回收基本步骤

混合回收的并发标记为什么从YGC开始

YGC与MixedGC是什么关系

MixedGC的并发标记从哪里开始

哪些region会被回收

混合回收是否会真的要执行

相关推荐
0110_102410 分钟前
tauri + rust的环境搭建---初始化以及构建
开发语言·后端·rust
会开花的二叉树11 分钟前
C++微服务 UserServer 设计与实现
开发语言·c++·微服务
一水鉴天14 分钟前
整体设计 逻辑系统程序 之34七层网络的中台架构设计及链路对应讨论(含 CFR 规则与理 / 事代理界定)
人工智能·算法·公共逻辑
像风一样自由202015 分钟前
Rust Tokio vs Go net/http:云原生与嵌入式生态选型指南
开发语言·golang·rust
DuHz17 分钟前
C程序中的数组与指针共生关系
linux·c语言·开发语言·嵌入式硬件·算法
而后笑面对17 分钟前
力扣2025.10.19每日一题
算法·leetcode·职场和发展
我星期八休息20 分钟前
C++智能指针全面解析:原理、使用场景与最佳实践
java·大数据·开发语言·jvm·c++·人工智能·python
摇滚侠20 分钟前
Spring Boot 3零基础教程,WEB 开发 整合 Thymeleaf 笔记36
java·spring boot·笔记
大猫会长25 分钟前
docker安装php+apache
java·开发语言
野生技术架构师27 分钟前
JAVA 架构师面试题含答案:JVM+spring+ 分布式 + 并发编程
java·jvm·spring