JAVA的平凡之路——此峰乃是最高峰JVM-GC垃圾回收器(2)-06

一、 触发GC

1、都有什么gc

Young gc、 Full gc、 Mixed gc

2、区别是什么

|------|-------------|-----------|---------|
| | Young gc | Mixed gc | Full gc |
| 执行节点 | 年轻代满了 | 老年代到达阀值 | 老年代满了 |
| 操作区域 | 年轻代+老年代(移入) | 年轻代+部分老年代 | 堆内所有区域 |
| 操作方式 | STW | STW | STW |
| 执行频率 | 高 | 中 | 低 |
| 执行成本 | 高 | 中 | 低 |

3、避免的gc

我们一般说的避免gc,指向的是full gc,因为full gc,设计区域广并且停顿时间长,会对用户体验造成不可逆影响。

二、细数GC

1、目前主流gc

(1)Serial

最早的gc回收器,年轻代,使用的是标记复制,单线程年轻代回收器。

(2)Serial Old

Serial 对应的老年代回收器,使用的标记整理,单线程老年代回收器。

(3)Parallel

Serial的多线程版本,多线程年轻代回收器 注重吞吐量

(4)Parallel Old

Serial Old的多线程版本,多线程老年代回收器

(5)ParNew

并行年轻代收集器,与CMS收集器配合使用

(6)CMS

真正意义上的并发收集器,老年代,4-8g时内存使用

(7)G1

逻辑分代,但是物理不分代的并发收集器,8g以上内存再考虑

(8)ZGC

不分代的并发收集器,100g内存再考虑

2、CMS并发收集器

图1.1

初始标记和重新标记都是STW,其余阶段都是并发处理

3、G1并发收集器

图1.2

初始标记、最终标记、筛选回收都是STW

4、ZGC并发回收器

图1.3

初始标记时会有短暂停顿,卖点是大内存,低停顿

三、查缺补漏

1、zgc的读屏障和颜色指针

对象指针在局部变量表中,64位的指针的高位进行对象状态存储,原有gc状态是保存在内存中的对象头中,所以减少了再根据指针查询对象的操作,降低消耗。

m0、m1都是标记位,只是根据周期不同进行使用,并且根据周期不同还会出现00、01、10、11等特殊含义,1为标记,0为不标记,标记为不回收,cms里面就有一个标记重置的处理,所以为了减少标记位重置的消耗,使用两个标记位交替使用。

读屏障,如果处于并发重分配阶段,访问会进到读屏障中,会根据转发表里的新纪录转发到新复制的对象上

相关推荐
椰猫子1 分钟前
SpringMVC(SpringMVC简介、请求与响应(请求映射路径、请求参数、日期类型参数传递、响应json数据))
java·前端·数据库
通往曙光的路上1 分钟前
JVM面试题
jvm
海兰3 分钟前
【开篇】Spring AI、OpenClaw 和Hermes
java·人工智能·spring·spring ai
skilllite作者6 分钟前
Zed 1.0 编辑器深度评测与实战指南
开发语言·人工智能·windows·python·编辑器·agi
2401_882273727 分钟前
pattern属性在旧版Android浏览器无效怎么办_手动验证补充【操作】
jvm·数据库·python
bzmK1DTbd11 分钟前
微服务架构设计:Spring Cloud Gateway与Nacos集成
java·spring·微服务
上弦月-编程12 分钟前
指针编程:高效内存管理核心
java·数据结构·算法
罗超驿13 分钟前
双指针算法经典案例:LeetCode 283. 移动零(Java详解)
java·算法·leetcode
xieliyu.14 分钟前
Java手搓数据结构:栈与队列模拟实现
java·数据结构·学习
清水白石00815 分钟前
深入 Python 循环引用与垃圾回收:如何应对内存管理的挑战
java·jvm·python