异常 try catch finally return 执行关系 MD
| MyAndroidBlogs | baiqiantao | baiqiantao | bqt20094 | baiqiantao@sina.com |
異常 try catch finally return 執(zhí)行關(guān)系 MD
目錄
目錄探討finally語(yǔ)句的執(zhí)行與return的關(guān)系
探討finally語(yǔ)句的執(zhí)行與return的關(guān)系
Java異常捕獲機(jī)制try...catch...finally塊中的finally語(yǔ)句是不是一定會(huì)被執(zhí)行?不一定,至少有兩種情況下finally語(yǔ)句是不會(huì)被執(zhí)行的:
- try語(yǔ)句沒有被執(zhí)行到,如在try語(yǔ)句之前就返回了,這樣finally語(yǔ)句就不會(huì)執(zhí)行,這也說(shuō)明了finally語(yǔ)句被執(zhí)行的必要而非充分條件是:相應(yīng)的try語(yǔ)句一定被執(zhí)行到。
- 在try塊中有System.exit(0)這樣的語(yǔ)句,System.exit(0)是終止Java虛擬機(jī)JVM的,連JVM都停止了,所有都結(jié)束了,當(dāng)然finally語(yǔ)句也不會(huì)被執(zhí)行到。
1、finally語(yǔ)句是在try的return語(yǔ)句執(zhí)行之后,return返回之前執(zhí)行的
測(cè)試案例:
運(yùn)行結(jié)果:
try block finally block 直接返回或
try block return statement finally block 調(diào)用方法返回說(shuō)明try中的return語(yǔ)句先執(zhí)行了,但并沒有立即返回,而是等到finally執(zhí)行結(jié)束后再返回。
這里大家可能會(huì)想:如果finally里也有return語(yǔ)句,那么是不是就直接返回了,try中的return就不能返回了?看下面。
2、finally塊中的return語(yǔ)句會(huì)覆蓋try塊中的return返回
public class TestFinally {public static void main(String[] args) {System.out.println(test());}public static String test() {try {System.out.println("try block");return "在try中返回";} finally {System.out.println("finally block");return "在finally中返回";}// return "finally外面的return就變成不可到達(dá)語(yǔ)句,需要注釋掉否則編譯器報(bào)錯(cuò)";} }運(yùn)行結(jié)果:
try block finally block 在finally中返回這說(shuō)明finally里的return直接返回了,就不管try中是否還有返回語(yǔ)句。
這里還有個(gè)小細(xì)節(jié)需要注意,finally里加上return過后,finally外面的return b就變成不可到達(dá)語(yǔ)句了,也就是永遠(yuǎn)不能被執(zhí)行到,所以需要注釋掉否則編譯器報(bào)錯(cuò)。
3、如果finally語(yǔ)句中沒有return語(yǔ)句覆蓋返回值,那么原來(lái)的返回值可能因?yàn)閒inally里的修改而改變,也可能不變
測(cè)試用例:
運(yùn)行結(jié)果:
try block finally block 100測(cè)試用例2:
public class TestFinally {public static void main(String[] args) {System.out.println(test());}public static List<Integer> test() {List<Integer> list = new ArrayList<Integer>();list.add(10086);try {System.out.println("try block");return list;} finally {list.add(10088);System.out.println("finally block");}} }運(yùn)行結(jié)果:
try block finally block [10086, 10088]這其實(shí)就是Java到底是傳值還是傳址的問題了,簡(jiǎn)單來(lái)說(shuō)就是:Java中只有傳值沒有傳址。
這里大家可能又要想:是不是每次返回的一定是try中的return語(yǔ)句呢?那么finally外的return不是一點(diǎn)作用沒嗎?請(qǐng)看下面
4、try塊里的return語(yǔ)句在異常的情況下不會(huì)被執(zhí)行,這樣具體返回哪個(gè)看情況
public class TestFinally {public static void main(String[] args) {System.out.println(test());}public static int test() {int b = 0;try {System.out.println("try block");b = b / 0;return b += 1;} catch (Exception e) {b += 10;System.out.println("catch block");} finally {b += 100;System.out.println("finally block");}return b;} }運(yùn)行結(jié)果是:
try block catch block finally block 110這里因 為在return之前發(fā)生了異常,所以try中的return不會(huì)被執(zhí)行到,而是接著執(zhí)行捕獲異常的 catch 語(yǔ)句和最終的 finally 語(yǔ)句,此時(shí)兩者對(duì)b的修改都影響了最終的返回值,這時(shí)最后的 return b 就起到作用了。
這里大家可能又有疑問:如果catch中有return語(yǔ)句呢?當(dāng)然只有在異常的情況下才有可能會(huì)執(zhí)行,那么是在 finally 之前就返回嗎?看下面。
5、當(dāng)發(fā)生異常后,catch中的return執(zhí)行情況與未發(fā)生異常時(shí)try中return的執(zhí)行情況完全一樣
public class TestFinally {public static void main(String[] args) {System.out.println(test());}public static int test() {int b = 0;try {System.out.println("try block");b = b / 0;return b += 1;} catch (Exception e) {b += 10;System.out.println("catch block");return 10086;} finally {b += 100;System.out.println("finally block");}//return b;} }運(yùn)行結(jié)果:
try block catch block finally block 10086說(shuō)明了發(fā)生異常后,catch中的return語(yǔ)句先執(zhí)行,確定了返回值后再去執(zhí)行finally塊,執(zhí)行完了catch再返回,也就是說(shuō)情況與try中的return語(yǔ)句執(zhí)行完全一樣。
總結(jié):
- finally塊的語(yǔ)句在try或catch中的return語(yǔ)句執(zhí)行之后返回之前執(zhí)行
- 且finally里的修改語(yǔ)句可能影響也可能不影響try或catch中return已經(jīng)確定的返回值
- 若finally里也有return語(yǔ)句則覆蓋try或catch中的return語(yǔ)句直接返回
2019-3-4
轉(zhuǎn)載于:https://www.cnblogs.com/baiqiantao/p/10472137.html
總結(jié)
以上是生活随笔為你收集整理的异常 try catch finally return 执行关系 MD的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 微信小程序集成腾讯云 IM SDK
- 下一篇: 浦发台北故宫文化主题信用卡怎么样?各种权