如何判断一个对象实例是否死亡

本文详细介绍了Java中判断对象实例死亡的两种算法:引用计数和可达性分析,并探讨了不同类型的引用(强引用、软引用、弱引用、虚引用)及其在内存管理中的作用。通过实例展示了对象在 finalize() 方法执行前的“挣扎”过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、判断对象是否死亡算法
有以下两种算法判断对象实例是否死亡:
1、引用计数算法:给每个对象添加一个引用计数器,当有对象引用时加1,当引用失效时减1,任何引用计数器为0的对象实例就是不可能再被使用的——对象实例死亡。但它无法解决对象相互引用的情况。
2、可达性分析算法:通过一系列被称为“GC Roots”的对象作为起始点,从这些节点开始向下搜索,搜索所走过的路径称为引用链,当一个对象到GC Roots没有任何引用链相连时,则说明此对象不能再被使用——对象实例已死亡。可作为GC Roots的对象包括:虚拟机栈中引用的对象,方法区中类静态属性引用的对象,方法区常量引用的对象,本地方法栈中本地方法引用的对象。
二、引用的种类
1、强引用:类似“Object a = new Object();”的引用,只要引用还存在就不会被垃圾搜集器回收
2、软引用:用来描述有用但非必需的对象,在系统内存不足时会对软引用对象进行标记,然后进行垃圾回收,若此次回收内存依旧不足,将会进行第二次垃圾回收对软引用对象进行回收,下面看看实例

/*设置Java参数
	-XX:+PrintGCDateStamps
	-XX:+PrintGCDetails
	-Xloggc:./gc.log
	-Xms12M
	-Xmx12M
*/
public class SoftReferenceTest{
   
	class Teather {
   
	    private byte[] name = new byte[7*1024*1024];
	}
	class Student {
   
	    private byte[] name = new byte[2*1024*1024];
	}
	public static void main(String[] args) throws InterruptedException {
   
	        Teather teather = new Teather()
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值