1. 清理资源(Java提供的 默认机制:finalize()方法)
2. 垃圾回收机制回收某个对象所占用的内存
先执行1,再执行2.系统将会严格按照这个次序来。
只有当程序认为需要更多的额外内存时,垃圾回收机制才会进行垃圾回收。所以可能出现这样的一种情形:
当某个对象没有引用再指向他的时候,他只占用了少量的内存,而系统也没有严重的内存需求,垃圾回收机制就没有试图去回收该对象所占用的资源,所以该对象的finalize方法也不会得到调用。
示例:
class FinalizeTest{
private static FinalizeTest ft=null;
public void info(){
System.out.println("测试清理资源的finalize方法");
}
public void finalize(){
ft=this;
}
public static void main(String[] args) {
new FinalizeTest();
//通知系统进行垃圾回收
Runtime.getRuntime().gc();//1
//等价于System.gc();
Runtime.getRuntime().runFinalization();//2
//等价于System.runFinalization();
ft.info();
}
}
只有1,没有2:空指针异常。虽然你强制垃圾回收机制(只是一种建议)进行回收,但是JVM可能并不是马上就去调用可恢复对象的finalize方法,所以ft可能为null。
只有2,没有1:空指针异常。由于没有通知垃圾回收机制进行垃圾回收,如果程序内存不紧张,那么系统通常是更不可能立即进行垃圾回收,也就更不可能会去调用FinalizeTest对象的finalize()方法,所以ft也就是为null。