finally語句包含return的情況

2021-09-08 12:18:44 字數 1821 閱讀 6053

結論:

1、不管有木有出現異常,finally塊中**都會執行;

2、當try和catch中有return時,finally仍然會執行;

3、finally是在return後面的表示式運算後執行的(此時並沒有返回運算後的值,而是先把要返回的值儲存起來,管finally中的**怎麼樣,返回的值都不會改變,任然是之前儲存的值),所以函式返回值是在finally執行前確定的;

4、finally中最好不要包含return,否則程式會提前退出,返回值不是try或catch中儲存的返回值。

舉例:情況1:try{} catch(){}finally{} return;

顯然程式按順序執行。

情況2:trycatch(){} finally{} return;

程式執行try塊中return之前(包括return語句中的表示式運算)**;

再執行finally塊,最後執行try中return;

finally塊之後的語句return,因為程式在try中已經return所以不再執行。

情況3:try catch() finally{} return;

程式先執行try,如果遇到異常執行catch塊,

有異常:則執行catch中return之前(包括return語句中的表示式運算)**,再執行finally語句中全部**,

最後執行catch塊中return. finally之後也就是4處的**不再執行。

無異常:執行完try再finally再return.

情況4:trycatch(){} finally

程式執行try塊中return之前(包括return語句中的表示式運算)**;

再執行finally塊,因為finally塊中有return所以提前退出。

情況5:try{} catch()finally

程式執行catch塊中return之前(包括return語句中的表示式運算)**;

再執行finally塊,因為finally塊中有return所以提前退出。

情況6:trycatch() finally

程式執行try塊中return之前(包括return語句中的表示式運算)**;

有異常:執行catch塊中return之前(包括return語句中的表示式運算)**;

則再執行finally塊,因為finally塊中有return所以提前退出。

無異常:則再執行finally塊,因為finally塊中有return所以提前退出。

最終結論:任何執行try 或者catch中的return語句之前,都會先執行finally語句,如果finally存在的話。

如果finally中有return語句,那麼程式就return了,所以finally中的return是一定會被return的,

編譯器把finally中的return實現為乙個warning。

下面是個測試程式public class finallytest  

static int test()

finally

}}結果是2。

分析:
在try語句中,在執行return語句時,要返回的結果已經準備好了,就在此時,程式轉到finally執行了。

在轉去之前,try中先把要返回的結果存放到不同於x的區域性變數中去,執行完finally之後,在從中取出返回結果,

因此,即使finally中對變數x進行了改變,但是不會影響返回結果。

它應該使用棧儲存返回值。

finally語句包含return的情況

結論 1 不管有木有出現異常,finally塊中 都會執行 2 當try和catch中有return時,finally仍然會執行 3 finally是在return後面的表示式運算後執行的 此時並沒有返回運算後的值,而是先把要返回的值儲存起來,管finally中的 怎麼樣,返回的值都不會改變,任然是...

finally語句的執行分析

2012 11 19 10 29 1466人閱讀收藏 舉報 學習疑惑 6 目錄 public classtest staticinttest finally 執行結果 子子子子2 dddddddddd1 執行結果是1,為什麼呢?主函式呼叫子函式並得到結果的過程,好比主函式準備乙個空罐子,當子函式要返...

finally 語句的妙用2

雖然標題說是finally 語句的妙用,但其實是finally 的錯誤用法。我們在編寫的時候應該時刻的避免這種情況的發生!言歸正傳,finally 語句的這個妙用的用途是丟失異常。如下 class veryimportantexception extends exception class hohu...