一步一图:那JVM老年代垃圾回收器CMS工作时,内部又干了些啥?

本文深入探讨了CMS(Concurrent Mark Sweep)垃圾回收器的工作原理,解释了如何在系统运行时进行垃圾回收,以及其四个阶段:初始标记、并发标记、重新标记和并发清理。CMS使用标记-清理算法,避免长时间停顿,通过与应用程序并发执行大部分操作来提高性能。
摘要由CSDN通过智能技术生成

添加VX:ruyuan0220,回复:CSDN,领取更多精品学习资料!

目录

背景知识

CMS垃圾回收的基本原理

如果Stop the World然后垃圾回收会如何?

CMS如何实现系统一边工作的同时进行垃圾回收?

对CMS的垃圾回收机制进行性能分析

思考题


背景知识

对象分配在新生代的Eden区,每次垃圾回收之后,存活对象都进入Survivor区,然后下一次垃圾回收后的存活对象都进入另外一个Survivor区。

这样几乎很少很少的对象会进入老年代里去,也就几乎不太会触发老年代的垃圾回收了。

但是理想很丰满,现实很骨干。其实大家想想,你们在写代码的时候,有谁会考虑垃圾回收啥的?不会有人考虑这个吧,就是不停的狂写代码,然后直接上线部署,根本没多少人会考虑自己的代码对垃圾回收的影响。

最多有经验的工程师上线之前,通过我们之前的案例讲解的方法估算一下系统的内存压力以及垃圾回收的运行模型,然后合理设置一下内存各个区域的大小,尽量避免太多对象进行老年代里去。

但是真实情况是,线上系统很可能就会因为各种各样的情况,导致很多对象进入老年代,然后甚至频繁触发老年代的Full GC。

之前我们用案例给大家演示过很多这种情况,比如说Survivor区太小,容纳不了每次Minor GC后的存活对象,导致对象频繁进入老年代,频繁触发老年代Full GC。

类似的情况其实很多,所以,咱们不能过于理想化的期待永远没有老年代GC,还是要对老年代的垃圾回收器是如何回收的,有一个了解和认识。

CMS垃圾回收的基本原理

一般老年代我们选择的垃圾回收器是CMS,他采用的是标记清理算法,其实非常简单,就是先用之前文章里讲过的标记方法去标记出哪些对象是垃圾对象,然后就把这些垃圾对象清理掉,如下图所示。

上面图里是一个老年代内存区域的对象分布情况,现在假设因为老年代内存空间小于了历次Minor GC后升入老年代对象的平均大小,判断Minor GC有风险,可能就会提前触发Full GC回收老年代的垃圾对象。

或者是一次Minor GC后的对象太多了,都要升入老年代,发现空间不足,出

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值