本文研究的主要是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()方法實例代碼的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。