JVM垃圾回收的过程

https://www.cnblogs.com/liwangcai/p/10752686.html
垃圾回收的过程分为两步:

1.判断对象是否死亡

(1)引用计数器法:

①每当有一个对象引用是,计数器加一,当计数器为0是对象死亡

②缺点:无法解决循环引用的问题,假设A引用B,B引用A,那么这两个对象将不会被回收,造成内存泄漏

(2)可达性算法分析

①通过一系列可作为GC Roots的节点为起始点,从这些节点开始往下搜索,所走过的路径称为引用链。

②当一个对象到GC Roots节点没有引用链时,说明对象不可用

③可作为GC Roots节点的对象

虚拟机栈中引用的对象

本地方法栈中引用的对象

方法区中静态变量引用的对象

方法区中常量引用的对象

2.垃圾回收算法进行回收

(1)标记-清除:即直接将标记为死亡的对象清除,缺点是会产生垃圾碎片

(2)标记-整理:即将可用的对象同意向一端移动,将边界外的对象清除

(3)复制算法:即将堆分为了Eden,SurvivorFrom,SurvivorTo空间

①每次在Eden空间上分配对象

②SurvivorFrom空间为上次垃圾回收是还存活的对象

③SurvivorTo空间为本次垃圾回收是生存的对象存放的位置

④本次垃圾回收结束后交换SurvivorFrom与SurvivorTo

⑤复制算法需要担保空间,当有一个大的对象要分配,而Eden空间又不足时会直接分配到老年代

⑥在对象生存率较高时会进行大量的复制操作,降低效率

(4)分代回收算法:根据新生代与老年代对象的特点而使用不同的垃圾会回收算法

①新生代:对象生存周期较短,只有少量的生存对象,适合使用复制算法

②老年代:对象生存周期较长,只又少量需要回收的对象,且无担保空间,所以使用标记-整理算法或者是标记-清除算法

3.根据不同的垃圾回收算法在Jvm中实现了多种垃圾回收器

发布了115 篇原创文章 · 获赞 22 · 访问量 3万+

猜你喜欢

转载自blog.csdn.net/weixin_42956047/article/details/105250362