Java中关于覆盖finalize()方法的一次尝试

Java中关于覆盖finalize()方法的一次尝试

测试代码

package com.alioo.gc;

/**
 * 执行结果:
 *
 */
public class FinalizeEscapeGC{
    public static FinalizeEscapeGC instance=null;
    public void isAlive(){
        System.out.println("yes,i am still alive");
    }
    @Override
    protected void finalize() throws Throwable {
        super.finalize();
        System.out.println("finalize methode executed");
        instance=this;
    }

    public static void main(String [] args) throws InterruptedException {
        instance=new FinalizeEscapeGC();

        instance=null;
        System.gc();
        Thread.sleep(1000);
        instance.isAlive();  //在没有重写finalize方法时,肯定是会报nullpointerException的

        instance=null;
        System.gc();
        Thread.sleep(1000);
        instance.isAlive();
    }
}

执行结果:

finalize methode executed
yes,i am still alive
Exception in thread "main" java.lang.NullPointerException
    at com.alioo.gc.FinalizeEscapeGC.main(FinalizeEscapeGC.java:29)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at com.intellij.rt.execution.application.AppMain.main(AppMain.java:134)

解释说明:
先执行 instance=null;后执行instance.isAlive(); 在没有重写finalize方法时,肯定是会报nullpointerException的,
但是实际执行结果是一次逃脱成功,一次失败,这是因为任何一个对象的finalize()方法都只会被系统自动调用一次,如果对象面临下一次回收,它的finalize()方法就不会再次执行

总结:
这个拯救对象的方式带有极大的不确定性,建议大家不用使用它,忘掉这个方法的存在

猜你喜欢

转载自blog.csdn.net/hl_java/article/details/79136049