本文研究的主要是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()方法實例代碼的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!