解決java?try?throw?exception?finally遇上return?break?continue造成異常丟失
如下所示
是一個(gè)java筆試題
考察的是拋出異常之后,程序運(yùn)行結(jié)果,但是這里拋出異常,并沒有捕獲異常,而是通過finally來進(jìn)行了流程控制處理。
package com.xxx.test;
public class ExceptionFlow {
public static void main(String[] args) {
try {
System.out.println("hello " + func());
} catch (Exception e) {
e.printStackTrace();
}
}
public static int func() {
int a = 0;
for (int i = 0; i < 3; i++) {
try {
throw new RuntimeException("xx");
} finally {
continue;
}
}
return a;
}
}運(yùn)行程序,打印結(jié)果如下所示:

這里結(jié)果有些出人意料,并沒有打印異常信息,其實(shí)就是try finally遇到了continue,導(dǎo)致異常信息丟失。
如果這里,我們稍微改變一下,把finally中的continue注釋,
再來看看結(jié)果:

這次打印了異常信息。
下面再來看看另一個(gè)例子
package com.xxx.test;
public class ExceptionDemo {
public static void main(String[] args) {
try {
func();
System.out.println("A");
} catch (Exception e) {
System.out.println("C");
}
System.out.println("D");
}
public static void func() {
try {
throw new Exception();
} finally {
System.out.println("B");
}
}
}這里要求寫出程序運(yùn)行結(jié)果。
這道題的答案其實(shí)就是編譯不通過,
如下所示:

這里需要在func方法簽名上聲明拋出異常。
方法簽名上添加了拋出異常,這里就編譯成功,運(yùn)行結(jié)果是B C D。
這里其實(shí)也可以不用在方法簽名上進(jìn)行聲明,直接把異常改成自定義異常RuntimeException("xx"),最終程序運(yùn)行結(jié)果也是一樣的。
這里我們按照第一個(gè)題目的思路,把finally中添加return信息,這時(shí)候,運(yùn)行結(jié)果會(huì)變?yōu)锽 A D。

因?yàn)楫惓P畔G失,所以在調(diào)用func()的地方,進(jìn)行try catch的時(shí)候,就不會(huì)有異常信息,那么程序就會(huì)按照正常的流程運(yùn)行。
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SprinBoot整合Quart實(shí)現(xiàn)定時(shí)調(diào)度的示例代碼
這篇文章主要介紹了SprinBoot整合Quart實(shí)現(xiàn)定時(shí)調(diào)度的示例代碼,代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-10-10
java連接MySQL數(shù)據(jù)庫實(shí)現(xiàn)代碼
這篇文章主要為大家詳細(xì)介紹了java連接MySQL數(shù)據(jù)庫實(shí)現(xiàn)代碼,感興趣的小伙伴們可以參考一下2016-06-06
springboot+HttpInvoke?實(shí)現(xiàn)RPC調(diào)用的方法
RPC框架大家或多或少都用過,出自于阿里系的就有dubbo,HSF,sofaRPC等,今天通過本文給大家介紹springboot+HttpInvoke?實(shí)現(xiàn)RPC調(diào)用的方法,感興趣的朋友一起看看吧2022-03-03

