淺談java中異常拋出后代碼是否會繼續(xù)執(zhí)行
問題
今天遇到一個問題,在下面的代碼中,當拋出運行時異常后,后面的代碼還會執(zhí)行嗎,是否需要在異常后面加上return
語句呢?
public void add(int index, E element){ if(size >= elements.length) { throw new RuntimeException("順序表已滿,無法添加"); //return; //需要嗎? } .... }
為了回答這個問題,我編寫了幾段代碼測試了一下,結(jié)果如下:
//代碼1 public static void test() throws Exception { throw new Exception("參數(shù)越界"); System.out.println("異常后"); //編譯錯誤,「無法訪問的語句」 }
//代碼2 try{ throw new Exception("參數(shù)越界"); }catch(Exception e) { e.printStackTrace(); } System.out.println("異常后");//可以執(zhí)行
//代碼3 if(true) { throw new Exception("參數(shù)越界"); } System.out.println("異常后"); //拋出異常,不會執(zhí)行
總結(jié):
若一段代碼前有異常拋出,并且這個異常沒有被捕獲,這段代碼將產(chǎn)生編譯時錯誤「無法訪問的語句」。如代碼1
若一段代碼前有異常拋出,并且這個異常被try...catch
所捕獲,若此時catch
語句中沒有拋出新的異常,則這段代碼能夠被執(zhí)行,否則,同第1條。如代碼2
若在一個條件語句中拋出異常,則程序能被編譯,但后面的語句不會被執(zhí)行。如代碼3
另外總結(jié)一下運行時異常與非運行時異常的區(qū)別:
運行時異常是RuntimeException
類及其子類的異常,是非受檢異常,如NullPointerException
、IndexOutOfBoundsException
等。由于這類異常要么是系統(tǒng)異常,無法處理,如網(wǎng)絡(luò)問題;
要么是程序邏輯錯誤,如空指針異常;JVM必須停止運行以改正這種錯誤,所以運行時異??梢圆贿M行處理(捕獲或向上拋出,當然也可以處理),而由JVM自行處理。Java Runtime
會自動catch
到程序throw
的RuntimeException
,然后停止線程,打印異常。
非運行時異常是RuntimeException
以外的異常,類型上都屬于Exception
類及其子類,是受檢異常。非運行時異常必須進行處理(捕獲或向上拋出),如果不處理,程序?qū)⒊霈F(xiàn)編譯錯誤。一般情況下,API中寫了throws
的Exception
都不是RuntimeException
。
常見運行時異常:
常見非運行時異常:
好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
相關(guān)文章
Java實戰(zhàn)寵物店在線交易平臺的實現(xiàn)流程
讀萬卷書不如行萬里路,只學(xué)書上的理論是遠遠不夠的,只有在實戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+Springboot+maven+Mysql+FreeMarker實現(xiàn)一個寵物在線交易系統(tǒng),大家可以在過程中查缺補漏,提升水平2022-01-01Java數(shù)據(jù)結(jié)構(gòu)和算法之冒泡,選擇和插入排序算法
這篇文章主要為大家介紹了Java冒泡,選擇和插入排序算法 ,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-01-01SpringCloud Config統(tǒng)一配置中心問題分析解決與客戶端動態(tài)刷新實現(xiàn)
springcloud config是一個解決分布式系統(tǒng)的配置管理方案。它包含了 client和server兩個部分,server端提供配置文件的存儲、以接口的形式將配置文件的內(nèi)容提供出去,client端通過接口獲取數(shù)據(jù)、并依據(jù)此數(shù)據(jù)初始化自己的應(yīng)用2022-10-10Java實現(xiàn)excel表格轉(zhuǎn)成json的方法
本篇文章主要介紹了Java實現(xiàn)excel表格轉(zhuǎn)成json的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09