可达性分析算法-针对的对象

可达性分析算法是JVM垃圾回收的基础,它通过根节点集合(包括虚拟机栈、本地方法栈、静态属性引用和常量引用等)来判断对象是否存活。在内存管理中,对象分为强引用、软引用、弱引用和虚引用四类,不同程度地影响其存活状态。强引用的对象不会被回收,而软引用、弱引用和虚引用的对象在内存不足时或无引用时会被回收,以实现内存的有效利用。

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

  可达性分析算法的基本思想,(由于该算法是JVM垃圾回收判断对象死亡的基本算法)这里,我们对上一篇讲的关于可达性分析算法做一个更加细致的研究;

   首先是根节点(GC Roots):作为可达性算法的初始节点,什么样的节点可以做为根节点呢?

  1. 虚拟机栈(栈帧中的本地变量表)中引用的对象;
  2. 本地方法区中的静态属性引用对象;
  3. 方法区中的常量引用对象;
  4. 本地方法栈中的JNI(Native方法)的引用对象;

   在可达性算法中,表示可达的标准为是否有引用链与之相连,这个时候存在内存中的对象只有垃圾对象和非垃圾对象之分,但是,很多时候,有一些对象是再内存充足的时候可以留在内存中,方便之后调用,内存出现不足时,有需要讲该类对象进行垃圾回收,为其他的对象留出空间,很多系统的缓存功能都符合上述条件;

   Java中将引用分为强引用(Strong Reference),软引用(Soft Reference),弱引用(Weak Reference),虚引用(Phantom Reference)四种,引用强度逐渐降低;

强引用就是指在程序代码中普遍存在的引用,只要强引用在,垃圾搜集器永远不会搜集被引用的对象。

软引用是用来描述一些有用但并不是必需的对象,对于软引用关联着的对象,只有在内存不足的时候JVM才会回收该对象。

弱引用也是用来描述非必需对象的,当JVM进行垃圾回收时,无论内存是否充足,都会回收被弱引用关联的对象。

虚引用并不影响对象的生命周期,如果一个对象与虚引用关联,则跟没有引用与之关联一样,在任何时候都可能被垃圾回收器回收。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值