(1)引用计数法
思想:为每个对象添加一个引用计数器,每当有一个地方引用这个对象时,计数器的值就+1,;当引用失效时,计数器的值就-1,;任何时刻计数器的值为0的对象没有在被使用。 缺点:很难解决对象之间循环引用的问题,这时两个对象都不能被回收。
(2)可达性分析法
思想:通过一系列的成为“GC roots”的对象作为起始点,从这些节点,开始向下搜索,搜索所走过的路径称为引用链,当一个对象到GC roots没有任何引用链相连(就是从GC roots到这个对象不可达),则证明此对象是不可用的。 若对象在进行可达性分析后没有发现与GC roots相连接的引用链,那么它将会被第一次标记并进行一次筛选,筛选的条件是该对象是否有必要执行finalize()方法,在finalize ( )方法中,你要指定在一个对象被撤消前必须执行的操作。例如,如果一个对象正在处理的是非Java 资源,如文件句柄或window 字符字体,这时你要确认在一个对象被撤消以前要保证这些资源被释放。为处理这样的状况,Java 提供了被称为收尾(finalization )的机制。
Java初高级一起学习分享,共同学习才是最明智的选择,喜欢的话可以我的学习群64弍46衣3凌9,或加资料群69似64陆0吧3
使用该机制你可以定义一些特殊的操作,这些操作在一个对象将要被垃圾回收程序释放时执行。当对象没有重写finalize()方法,或者finalize()方法已经被虚拟机调用过,虚拟机将这两种情况都视为没必要执行。任何一个对象的finalize()方法都只会系统调用一次。若该对象判定为有必要执行finalize()方法,则这个对象会被放在一个F-Queue队列,finalize方法是对象逃脱死亡命运的最后一次机会,稍后GC将对F-Queue中的对象进行第二次标记(对象执行完finalize()),若对象要在finalize中成功拯救自己----只要重新与引用链上的任何一个对象建立关联即可,那么在第二次标记时,它们会被移出“即将回收”集合。
注:
(1)可作为GC roots的对象 java虚拟机栈(栈帧中的本地变量表)中引用的对象。 方法区中类的静态属性引用的对象。 方法区中常量引用的对象。 本地方法栈中JNI(java本地接口)引用的对象。
(2)引用强度 强引用》软引用》弱引用》虚引用
(3)finalize()函数不是c或c++的析构函数。