在可达性分析算法中的不可达对象还要至少经历两次标记过程,才会真正被系统回收。
第一次标记:
对象在可达性分析后为不可达。
筛选:
筛选出没有覆盖finalize()方法且finalize()方法没有被虚拟机调用过的对象,放置在一个叫做F-Queue的队列,由虚拟机自动建立的、低优先级的Finalizer线程去执行对象的finalize()方法(任何一个对象的finalize()方法只会被系统自动调用一次)。
第二次标记:
由GC对F-Queue中的对象进行标记,如果对象在finalize()方法中重新与引用链上的任一对象建立联系(不建议),将被移除“即将回收”的集合,否则被回收。