判断方式

GC对JAVA堆内对象的是否进行回收的判断准则:对象dead or alive 。死亡的才会进行回收,两种方式进行判断 引用计数法 引用链法(可达性分析)

一 引用计数法

给java对象添加一个引用计数指针,每当有一个地方引用它时 计数+1引用失效则计数-1

当计数器不为0时候 alive 为0 dead

优点:实现简单 判断高效

缺点:无法判断对象间相互循环引用的问题

二 引用链法

很多主流商用语言(如Java、C#)都采用 引用链法 判断 Java对象是否存活。包括三个步骤

 ·可达性分析

 ·第一次标记&筛选

 ·第二次标记&筛选

1 可达性分析

将一系列GC Rtoot对象作为起点,从这些起点开始向下搜索。可作为GC Root的对象有 java虚拟机栈中引用的数据 本地方法栈JNI中引用的数据 方法区中 常量 类静态属性引用的对象 向下搜索路径=引用链

当一个对象到GC Root是没有任何引用链相连时,则判断该对象不可达

不可达对象会被放在 即将回收 的集合中  


2 第一次筛选&标记

当对象被判断为不可达 将会进行第一次标记&准备被筛选

 a 不筛选 继续留在 即将回收 集合里 等待回收

 b 筛选 从即将回收 集合中取出

筛选的标准:该对象时候有必要执行finalize()方法

 若有必要执行(人为设置 即重写该方法) 则筛选出来 进入下一阶段(第二次标记&筛选)

 若没有必要(没有inalize()方法或者方法已经被执行过),判断该对象死亡,不筛选 并等待回收

3第二次筛选&标记

方式描述:该对象会被放在一个F-queue队列中,并由虚拟机自动建立 优先级较低的Finalizer线程去执行该对象中的Finalize()方法 Finalize()方法只会被执行一次,但实际上并不承诺完成整个方法(防止方法执行缓慢/停止导致队列其他对象永久等待)

筛选标准:再执行finalize()方法中 如果该对象仍然没有跟GC Roots发生关联 不筛选 留在 即将回收 集合中等待回收