有return的情況下try catch finally的執行順序總結

結論

  • 1、不管有木有出現異常,finally塊中代碼都會執行;
  • 2、當try和catch中有return時,finally仍然會執行;
  • 3、finally是在return後面的表達式運算後執行的(此時並沒有返回運算後的值,而是先把要返回的值保存起來,管finally中的代碼怎麼樣,返回的值都不會改變,任然是之前保存的值),所以函數返回值是在finally執行前確定的;
  • 4、finally中最好不要包含return,否則程序會提前退出,返回值不是try或catch中保存的返回值。

舉例:

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

顯然程序按順序執行。

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

程序執行try塊中return之前(包括return語句中的表達式運算)代碼;
再執行finally塊,最後執行try中return;
finally塊之後的語句return,因爲程序在try中已經return所以不再執行。

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

程序先執行try,如果遇到異常執行catch塊,
有異常:則執行catch中return之前(包括return語句中的表達式運算)代碼,再執行finally語句中全部代碼,
最後執行catch塊中return. finally之後也就是4處的代碼不再執行。
無異常:執行完try再finally再return.

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

程序執行try塊中return之前(包括return語句中的表達式運算)代碼;
再執行finally塊,因爲finally塊中有return所以提前退出。

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

程序執行catch塊中return之前(包括return語句中的表達式運算)代碼;
再執行finally塊,因爲finally塊中有return所以提前退出。

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

程序執行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  
{
    public static void main(String[] args) {

        System.out.println(new FinallyTest().test());;
    }

    static int test()
    {
        int x = 1;
        try
        {
            x++;
            return x;
        }
        finally
        {
            ++x;
        }
    }
}

結果是2。

  • 分析:

在try語句中,在執行return語句時,要返回的結果已經準備好了,就在此時,程序轉到finally執行了。
在轉去之前,try中先把要返回的結果存放到不同於x的局部變量中去,執行完finally之後,在從中取出返回結果,
因此,即使finally中對變量x進行了改變,但是不會影響返回結果。
它應該使用棧保存返回值。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章