本文研究的主要是Java中關(guān)于覆蓋finalize()方法的一次嘗試,具體實(shí)現(xiàn)如下。
測(cè)試代碼
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í)行結(jié)果: * */ 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(); //在沒(méi)有重寫finalize方法時(shí),肯定是會(huì)報(bào)nullpointerException的 instance= null ; System.gc(); Thread.sleep( 1000 ); instance.isAlive(); } } |
執(zhí)行結(jié)果:
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)
解釋說(shuō)明:
先執(zhí)行 instance=null;后執(zhí)行instance.isAlive(); 在沒(méi)有重寫finalize方法時(shí),肯定是會(huì)報(bào)nullpointerException的,
但是實(shí)際執(zhí)行結(jié)果是一次逃脫成功,一次失敗,這是因?yàn)槿魏我粋€(gè)對(duì)象的finalize()方法都只會(huì)被系統(tǒng)自動(dòng)調(diào)用一次,如果對(duì)象面臨下一次回收,它的finalize()方法就不會(huì)再次執(zhí)行
總結(jié)
這個(gè)拯救對(duì)象的方式帶有極大的不確定性,建議大家不用使用它,忘掉這個(gè)方法的存在。
以上就是本文關(guān)于Java中覆蓋finalize()方法實(shí)例代碼的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對(duì)本站的支持!
原文鏈接:http://blog.csdn.net/hl_java/article/details/79136049