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

🐵看完这篇文章,希望你有点收获🚗

注意:看之前你需要对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的发生。

相关推荐
旖旎夜光2 小时前
Linux(4)(下)
linux·学习
敲敲了个代码5 小时前
从硬编码到 Schema 推断:前端表单开发的工程化转型
前端·javascript·vue.js·学习·面试·职场和发展·前端框架
cike_y5 小时前
Mybatis之解析配置优化
java·开发语言·tomcat·mybatis·安全开发
是一个Bug6 小时前
Java基础50道经典面试题(四)
java·windows·python
Slow菜鸟6 小时前
Java基础架构设计(三)| 通用响应与异常处理(分布式应用通用方案)
java·开发语言
wadesir6 小时前
Rust中的条件变量详解(使用Condvar的wait方法实现线程同步)
开发语言·算法·rust
我是Superman丶6 小时前
《Spring WebFlux 实战:基于 SSE 实现多类型事件流(支持聊天消息、元数据与控制指令混合传输)》
java
廋到被风吹走7 小时前
【Spring】常用注解分类整理
java·后端·spring
是一个Bug7 小时前
Java基础20道经典面试题(二)
java·开发语言
yugi9878387 小时前
基于MATLAB实现协同过滤电影推荐系统
算法·matlab