在第7条避免使用终结方法中提到的finalize(),于是在查阅finalize()的时候有提到了垃圾回收机制,便一起阅读以下,记下一点笔记
当一个对象没有任何引用指向的时候,此时就可能会被垃圾回收,一旦垃圾回收期准备好释放对象占用的存储空间时,首先调用finalize()的方法,并且在下一次的垃圾回收动作发生时,才会真正的回收对象占用的内存,因此在finalize()里面可以做一些重要的清理工作。
来及回收期准备释放内存的时候,会先调用finalize(),对此有如下几点:
<1>对象不一定会被回收
<2>垃圾回收不是析构函数
<3>垃圾回收只与内存有关
<4>垃圾回收和finalize()都是靠不住的,只要JVM还没有到快耗尽内存的地步,它是不会浪费时间进行垃圾回收的
如同第7条中提到的一样,我们并不知道finalize()方法的调用会发生在什么时候,这样会很浪费时间,当要调用finalize()的时候使用System.gc或者直接调用finalize()方法
下面举个例子吧
在一个类中重载finalize()方法(是Object的方法),当使其对象的引用不存在时,是否会调用该方法
public class PersonCheck {
public static int fir=0;
public static final int id=++fir;
@Override
protected void finalize() throws Throwable {
// TODO Auto-generated method stub
super.finalize();
System.out.println(this.getClass()+": id="+id+" is finalized");
}
public PersonCheck(){
System.out.println("id="+id+" is created");
}
}
public class PersonCheckTest {
public static void main(String[] args) {
PersonCheck personCheck1=new PersonCheck();
PersonCheck personCheck2=new PersonCheck();
PersonCheck personCheck3=new PersonCheck();
personCheck1=personCheck2=null;
System.gc();
}
}
于是我强制调用System.gc(),结果finalize()方法才被调用,显示如下
id=1 is created
id=1 is created
class com.effectivejava.PersonCheck: id=1 is finalized
class com.effectivejava.PersonCheck: id=1 is finalized
具体的垃圾回收机制就不记述了
参考:
http://blog.sina.com.cn/s/blog_72827fb10101eqo5.html
http://my.oschina.net/u/2297250/blog/383407
http://www.cnblogs.com/hnrainll/archive/2013/11/06/3410042.html