解決java?try?throw?exception?finally遇上return?break?continue造成異常丟失
如下所示
是一個(gè)java筆試題
考察的是拋出異常之后,程序運(yùn)行結(jié)果,但是這里拋出異常,并沒(méi)有捕獲異常,而是通過(guò)finally來(lái)進(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é)果有些出人意料,并沒(méi)有打印異常信息,其實(shí)就是try finally遇到了continue,導(dǎo)致異常信息丟失。
如果這里,我們稍微改變一下,把finally中的continue注釋,
再來(lái)看看結(jié)果:
這次打印了異常信息。
下面再來(lái)看看另一個(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"); } } }
這里要求寫(xiě)出程序運(yùn)行結(jié)果。
這道題的答案其實(shí)就是編譯不通過(guò),
如下所示:
這里需要在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-10java連接MySQL數(shù)據(jù)庫(kù)實(shí)現(xiàn)代碼
這篇文章主要為大家詳細(xì)介紹了java連接MySQL數(shù)據(jù)庫(kù)實(shí)現(xiàn)代碼,感興趣的小伙伴們可以參考一下2016-06-06詳解SpringCloud Zuul過(guò)濾器返回值攔截
Zuul作為網(wǎng)關(guān)服務(wù),是其他各服務(wù)對(duì)外中轉(zhuǎn)站,通過(guò)Zuul進(jìn)行請(qǐng)求轉(zhuǎn)發(fā)。這篇文章主要介紹了詳解SpringCloud Zuul過(guò)濾器返回值攔截,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-06-06springboot+HttpInvoke?實(shí)現(xiàn)RPC調(diào)用的方法
RPC框架大家或多或少都用過(guò),出自于阿里系的就有dubbo,HSF,sofaRPC等,今天通過(guò)本文給大家介紹springboot+HttpInvoke?實(shí)現(xiàn)RPC調(diào)用的方法,感興趣的朋友一起看看吧2022-03-03