判断对象能否回收的两种方法:引用计数算法,可达性分析算法
引用计数算法:给对象添加一个引用计数器,当该对象被其它对象引用时计数加一,引用失效时计数减一,计数为0时,可以回收。
特点:占用了一些额外的内存空间来进行计数,原理简单,判定效率高
引用计数法简单易实现,但无法解决循环引用的问题。
(这种引用情况下,A和B的计数器始终大于等于1。)
应用:引用计数法适用于对象生命周期较短、没有循环引用的场景,
可达性分析算法:可以通过引用链到达"根"的对象存活,不可到达的对象可以回收。(这个"根" 名为GC Roots)
特点:能够正确处理循环引用,但实现相对复杂,需要递归遍历对象图。
应用:可达性分析适用于长生命周期、存在循环引用的场景,
"引用" 概念的扩充
引用强度由高到低为:
强引用:传统理解的"引用","Object obj=new Object()",强引用类型的对象不会被回收。(new 关键字创建的对象)
软引用:还有用,但非必须的对象,在系统将要内存溢出时会把它进行回收。(使用 SoftReference 类创建的引用)
弱引用:本次垃圾收集存活,但只能活到下一次垃圾收集为止。(使用WeakReference 类创建的引用)
虚引用:不会对对象的生存时间构成任何影响,唯一目的只是为了能在这个对象被收集器回收时收到一个通知。(使用 PhantomReference 类创建的引用)