本文研究的主要是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()方法就不会再次执行
这个拯救对象的方式带有极大的不确定性,建议大家不用使用它,忘掉这个方法的存在。
以上就是本文关于Java中覆盖finalize()方法实例代码的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#nhooo.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。