如何判断一个对象是否可以垃圾回收器被回收?

本文介绍了两种常用的垃圾回收算法:引用计数法和GCroots可达性算法。引用计数法简单直观,但存在资源消耗及无法解决循环引用等问题;GCroots可达性算法则通过追踪一系列根节点来判断对象是否可达,进而决定是否回收。

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

两大算法
1.引用计数法
每个对象都维护一个引用计数器,每个此对象被引用的时候就将计数器加一,当对象被取消引用的时候就将计数器减一,如果计数器为0,那么认为这个对象是垃圾,可以被回收。

引用计数法的缺点:

  • 每个对象都有一个引用计数器,维护这个引用计数器有一定的资源消耗
  • 无法解决循环引用的问题(假如说A对象中引用了B,B对象中引用了A,其他的所有对象都没有引用A和B对象,这个时候A和B对象其实就是垃圾,可以被回收,但是由于采用引用计数法,A和B对象的引用计数器都为1,所以垃圾回收器认为A和B对象不是垃圾,无法对他们进行回收)

2.GC roots可达性算法
思路:通过一系列名为GC roots的对象向下寻找,如果一个对象到GC roots对象没有任何的引用链,那么则可以认为这个对象是垃圾,可以被垃圾回收器回收。
在这里插入图片描述

其中 GC roots对象包括:

  1. 虚拟机栈中(栈帧中的局部变量表)引用的变量
  2. 本地方法栈中(Native方法)引用的变量
  3. 方法区中的常量引用的对象
  4. 方法区中的类静态属性引用的对象
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值