本文研究的主要是Java中關于覆蓋finalize()方法的一次嘗試,具體實現(xiàn)如下。
測試代碼
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
package com.alioo.gc; /** * 執(zhí)行結果: * */ 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(); } } |
執(zhí)行結果:
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)
解釋說明:
先執(zhí)行 instance=null;后執(zhí)行instance.isAlive(); 在沒有重寫finalize方法時,肯定是會報nullpointerException的,
但是實際執(zhí)行結果是一次逃脫成功,一次失敗,這是因為任何一個對象的finalize()方法都只會被系統(tǒng)自動調用一次,如果對象面臨下一次回收,它的finalize()方法就不會再次執(zhí)行
總結
這個拯救對象的方式帶有極大的不確定性,建議大家不用使用它,忘掉這個方法的存在。
以上就是本文關于Java中覆蓋finalize()方法實例代碼的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
原文鏈接:http://blog.csdn.net/hl_java/article/details/79136049