对象不可达时,会由垃圾回收器来回收与该对象相关联的内存资源;其他内存资源,一般由try-finally来完成。
1.除非是作为安全网或者是为了终结非关键的本地资源,否则请不要使用终结方法。
2.如果确实需要,可以使用显示终止方法
2.如果没办法真的使用了finalize,别忘记了调用super.finalize()。还可以考虑是否使用终结方法守卫者,使未调用super.finalize()方法的类的父类的终结方法也会被执行。
一、finalizer的缺点:
1. 不能保证及时/会执行。
及时执行finalizer方法是JVM垃圾回收方法的一个主要功能。由于不同JVM的垃圾回收算法不同,JVM会“非故意的”延迟执行终结方法,因此终结方法的执行时间点是非常不稳定的。
2.线程优先级低
3.System.gc和System.runFinalization不保证finalizer一定执行。
4.严重的(Severe)性能损失
二、显示终止方法 替代finalizer,实现线程中对象资源的终止
使用显示终止方法的要求:
1.记录已经被终止了
2.私有域中记录下“该对象已经不再有效”
3.检查“该对象已经不再有效”私有域,抛出IllegalStateException。
显示终止方法的例子:
1.InputStream
2.OutputStream
3.java.sql.Connection
4.java.util.Timer
FileInputStream fileInputStream = new FileInputStream();
try{
//Do something about fileInputStream;
}finally{
fileInputStream.close();
}
三、终结方法的好处。
1.作为安全网——显示终止方法忘记调用的时候
2.终止非关键的本地资源(android JNI操作中)
四、子类的终结过程出现异常,超类的终结过程也会得到执行。
终结方法链不会自动执行,因此我们需要手动保证这一点。
方法一:使用try – finalize 代码结构
@Override
protected void finalize() throws Throwable {
try{
...//Finalize subclass state
} finally {
super.finalize();
}
}
方法二:使用finalizer guardian(终结方法守卫者)
public class Foo{
//终结守卫
private final Object finalizerGuardian = newObject {
//释放Foo中的资源,这里不需要调用
super.finalize()
}
}
https://www.cnblogs.com/xerrard/p/5123546.html