JVM判断对象是否已死

本文介绍了Java中的两种垃圾收集算法:引用计数算法和可达性分析算法。引用计数算法简单直接,但无法处理循环引用问题。可达性分析算法从GCRoots出发,判断对象是否可达,对不可达对象进行回收。该算法会执行两次标记,包括对finalize()方法的处理,允许对象在最后有机会自救。理解这两种算法对于优化Java应用的内存管理至关重要。
摘要由CSDN通过智能技术生成
引用计数算法
在对象中添加一个引用计数器,每当有一个地方 引用它时,计数器值就加一;当引用失效时,计数器值就减一;任何时刻计数器为零的对象就是不可 能再被使用的。
可达性分析算法
通过一系列的称为“GC Roots”的对象作为起始点,从这些节点开始往下搜索,搜索走过的路径称为“引用链”,当一个对象到GC Roots没有任何引用链相连时(从GC Roots到这个对象不可达),证明此对象是不可用的。即会被判定为可回收对象。
Java中可作为GC Roots的对象包括:①虚拟机栈(栈帧中的本地变量表)中的引用的对象②方法区内类静态属性引用的对象③方法区内常量引用的对象④本地方法栈中JNI(Native方法)引用的对象;总的来说,就是方法运行时,方法引用的对象、类的静态变量引用的对象、类中常量引用的对象、Native方法中引用的对象。
在可达性分析算法中,要想真正宣告一个对象的死亡,
至少要经历两次标记过程 :①对象在进行可达性分析后,发现没有与GC Roots相连接的引用链,就会被 第一次标记 并进行一次筛选,筛选的条件是此对象是否有必要执行**finalize()**方法。当对象没有覆盖finalize()方法,或者finalize()方法已经被虚拟机调用过了,虚拟机将会把这两种情况视为“没有必要执行”; ②如果这个对象被判定为有必要执行finalize()方法,那么这个对象就会被放在F-Queue队列中,并在稍后被一个由虚拟机自动建立的、低优先级的Finalizer线程去执行它。 finalize()方法是对象逃脱死亡命运的最后一次机会 ,稍后GC回对F-Queue中的对象进行第二次小规模的标记,如果对象要在finalize()方法中成功自救,只需重新与引用链的的任意一个对象建立关联即可(如把自己赋值给某个类变量、对象的成员变量),那么在第二次标记时它会被从“即将回收”的集合移除。如果对象还没有逃脱,那就真没救了。

参考链接:https://blog.csdn.net/qq_36299025/article/details/90138672
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值