判断对象是否存活,有几种方法:
(1)引用计数法,即给对象添加一个引用计数器,有地方引用,则计数器+1,当引用失效,则计数器减1,任何时候计数器为0的对象就不可能再被使用了,这个方法简单高效,但是无法解决对象之间相互循环引用的问题;
(2)可达性分析算法,算法思想就是通过一系列的称为 “GC Roots” 的对象作为起点,从这些节点开始下向搜索,节点走过的路径称为饮用链,当一个对象到GCRoots没有任务引用链相连,则证明此对象是不可用的;
可作为GC Roots对象有一下几种:
虚拟机栈中引用的对象,方法区中类静态属性引用的对象,方法区中常量引用的对象,本地方法栈中Native方法引用的对象
JDK1.2 以后,Java 对引用的概念进行了扩充,将引用分为强引用、软引用、弱引用、虚引用四种(引用强度逐渐减弱)
如果一个对象具有强引用,那就类似于必不可少的生活用品,垃圾回收器绝不会回收它。
软引用,如果内存空间足够,垃圾回收器就不会回收它,如果内存空间不足了,就会回收这些对象的内存。
只具有弱引用的对象拥有更短暂的生命周期。在垃圾回收器线程扫描它 所管辖的内存区域的过程中,一旦发现了只具有弱引用的对象,不管当前内存空间足够与否,都会回收它的内存。
虚引用主要用来跟踪对象被垃圾回收的活动。
可达性分析法中不可达的对象,被真正回收之前,要进行2次标记的过程,可达性分析法中不可达的对象被第一次标记并且进行一次筛选,筛选的条件是此对象是否有必要执行finalize方法,或finalize方法已经被虚拟机调用过,虚拟机将这两种情况视为没有必要执行。被判定为需要执行的对象将会被放在一个队列中进行第二次标记,除非这个对象与引用链上的任何一个对象建立关联,否则就会被真的回收。