先來看一段**:
publicabstract
class
test
public
static
intbeforefinally()
finally
}}/**
output:
1*/
從結果上看,貌似`finally` 裡的語句是在`return` 之後執行的,其實不然,實際上`finally` 裡的語句是在在`return` 之前執行的。那麼問題來了,既然是在之前執行,那為什麼`a` 的值沒有被覆蓋了?
實際過程是這樣的:當程式執行到try{}語句中的return方法時,它會幹這麼一件事,將要返回的結果儲存到乙個臨時棧中,然後程式不會立即返回,而是去執行finally{}中的程式, 在執行`a = 2`時,程式僅僅是覆蓋了a的值,但不會去更新臨時棧中的那個要返回的值 。執行完之後,就會通知主程式「finally的程式執行完畢,可以請求返回了」,這時,就會將臨時棧中的值取出來返回。這下應該清楚了,要返回的值是儲存至臨時棧中的。
再來看乙個例子,稍微改下上面的程式:
publicabstract
class
test
public
static
intbeforefinally()
finally
}}/**
output:
2*/
在這裡,finally{}裡也有乙個return,那麼在執行這個return時,就會更新臨時棧中的值。同樣,在執行完finally之後,就會通知主程式請求返回了,即將臨時棧中的值取出來返回。故返回值是2.
try catch finally執行順序
public class test public static int ma catch exception e finally 說明 不出現異常情況 執行順序 try finally 出現異常情況 執行順序 try catch finally try中有返回語句,沒有異常 執行順序 try ret...
try catch finally執行順序
結論 1 不管有木有出現異常,finally塊中 都會執行 2 當try和catch中有return時,finally任會執行 3 finally是在return表示式運算後前執行的,所以函式返回值是在finally執行前確定的 4 finally中最好不要包含return,否則程式會提前退出,返回...
try catch finally使用體會
try catch finally public class finallytest static int test finally 結果是2。在try語句中,在執行return語句時,要返回的結果已經準備好了,就在此時,程式轉到finally執行了。在轉去之前,try中先把要返回的結果存放到不同於...