GC前判断对象是否还“存活”

引用计数法

给对象添加一个引用计数器,每当有一个地方引用它,计数值加1;当引用失效时,计数值减1;任何时刻计数器为0的对象就是不可能再被使用的。
特点:实现简单,判定效率高,但很难解决对象间相互循环引用的问题。

可达性分析算法

主流商用程序语言中的主流实现(Java、C#)。
通过一系列的称为“GC Roots”的对象作为起始点,从这些节点开始向下搜索,搜索走过的路径称为引用链,当一个对象到“GC Roots”没有任何引用链相连时,则此对象不可用,判定可回收。

对象“是生是死”?可达性分析算法至少要经历2次标记过程
对象是生是死
任何对象的finalize()只能被调用一次

在Java语言中,可作为“GC Roots”的对象有:
(1)虚拟机栈中引用的对象
(2)方法区中类静态属性引用的对象
(3)方法区中常量引用的对象
(4)本地方法栈中JNI引用的对象

关于引用
强引用

new出来的对象引用
只有强引用存在,就不会被GC

软引用

SoftReference类实现,描述还有用但非必需的对象
一般不会轻易回收,只有内存不够才会回收

弱引用

WeekReference类实现,描述非必需对象
一旦垃圾回收已启动,就会回收

虚引用

不能单独存在,必须和引用队列联合使用
主要用作跟踪对象被回收的状态

学习资料:《深入理解Java虚拟机_JVM高级特性与最佳实践 》

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值