‍♂️垃圾收集算法必看!学习指数满天星!!!

🐵看完这篇文章,希望你有点收获🚗
注意:看之前你需要对JVM有点了解。。。
首先,垃圾回收算法主要分有三种:

标记-清除算法

见名知意,标记-清除(Mark-Sweep)算法分为两个阶段:

  • 标记:标记出所有需要回收的对象。
  • 清除:回收所有被标记的对象
    在这里插入图片描述

标记-清除算法比较基础,但是主要存在两个缺点:

  • 执行效率不稳定:如果java堆中包含大量对象,而且其中大部分是需要被回收的。这时必须进行大量标记和清除的动作,导致标记和清除两个过程的执行效率都随对象数量的增加而降低。
  • 内存空间的碎片化问题: 标记、清除之后会产生大量不连续的内存碎片,空间碎片太多可能会导致以后程序在运行过程中,需要分配较大对象时,无法找到足够的连续内存而不得不提前触发另一次垃圾收集动作。
    PS:其实,可以边看边在脑子里想一下整个流程。

2.标记-复制算法

标记-复制算法解决了标记-清除算法面对大量可回收对象时执行效率低的问题。
过程呢!也很简单:将可用内存按容量划分为大小相等的两块,每次只使用其中的一块。当这一块的内存用完了,就将还存活着的对象复制到另一块上面,然后再把已使用过的内存空间一次清理掉。
在这里插入图片描述
这种算法存在一个明显的缺点:一部分空间没有使用,存在空间的浪费。
新生代垃圾收集主要采用这种算法,因为新生代的存活对象比较少,每次复制的只是少量的存活对象。当然,实际新生代的收集不是按照这个比例。

3.标记-整理算法

为了降低内存的消耗,引入一种针对性的算法:标记-整理(Mark-Sweep)算法。
其中的标记过程仍“标记-清除””算法一样,但后续步骤不是直接对可回收对象进行清理,而是让所有存活的对象都向内存空间一端移动,然后直接清理掉边界以外的内存。
在这里插入图片描述
标记-整理算法主要用于老年代,移动存活对象是个极为负重的操作,而且这种操作需要STW(Stop The World)才能进行,只能从整体的吞吐量来考量,老年代使用标记-整理算法更加合适。

除此之外!这次写博客,说了一个新的名词:STW

这是个啥意思呢!既然说到了,就简单说一哈!!!
Stop-The-World,简称STW,指的是GC事件发生过程中,会产生应用程序的停顿,停顿产生时整个应用程序线程都会被暂停,·没有任何响应,就有点像卡死了的感觉,这种停顿我们就称之为STW.
我们知道在JVM有种算法用来区分那些是可以进行回收的(可达性分析算法)。而这种算法中吗,枚举根节点(GC Roots)会导致所欲偶java执行线程停顿。
当然,STW的过程也有几个重要的点:

  1. 分析工作必须在一个能确保一致性的快照中进行。
  2. 一致性指整个执行系统看起来就像被冻结在某个时间点上。
  3. 如果出现分析过程中对象引用关系还在不断变化,则分析结果的准确性无法保证。

被STW中断的应用程序,线程会在完成GC之后恢复,频繁中断会让用户感觉像是网速不快造成电影卡带一样,所有我们需要减少STW的发生。
STW事件和采用哪款GC无关,所有的GC都有这个事件。哪怕是G1也不能完全避免stop-the-world情况发生,只能说明垃圾回收器越来越优秀,回收效率越来越高,尽可能地缩短了暂停时间。
STW是JVM在后台自动发起和自动完成的。在用户不可见的情况下,把用户正常的工作线程全部停掉。开发中不要用System,gc();会导致Stop-The-World的发生。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

熬夜想瑞瑞

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值