java 異常之手動拋出與自動拋出的實(shí)例講解
java異常處理機(jī)制的兩類
1、抓:異常的處理,有兩種方式
① try-catch-finally
② throws
2、拋:
① 自動拋出
可以理解為所有沒有使用throw關(guān)鍵字的異常處理都是自動拋出,由jvm進(jìn)行判斷和拋出。
②手動拋出
throw + 異常類的對象
》異常類可以是現(xiàn)成的,也可以是自己創(chuàng)建的異常類,
拋出異類的類型:若是RuntimException,可以不用顯示處理。
若是一個(gè)Exception,必須要顯示的處理。
/* *1.手動拋出一個(gè)異常的例子 */ public class TestException3 { public static void main(String[] args) { Circle c1 = new Circle(2.1); Circle c2 = new Circle(2.1); System.out.println(c2.compareTo(c2)); System.out.println(c1.compareTo(new String("44"))); } } class Circle{ private double radius; public Circle(double radius) { super(); this.radius = radius; } public double getRadius() { return radius; } public void setRadius(double radius) { this.radius = radius; } //比較兩個(gè)圓的半徑誰大 public int compareTo(Object obj) { if(this == obj) { return 0; } else if(obj instanceof Circle) { Circle c = (Circle)obj; if(this.radius > c.radius) { return 1; }else if(this.radius == c.radius){ return 0; }else { return -1; } }else { //因?yàn)樵谶@里返回聲明都不適合,手動的拋出一個(gè)異常 //運(yùn)行時(shí)異??梢圆挥蔑@示處理,在運(yùn)行的時(shí)候,拋出。 throw new RuntimeException("傳入的類型有誤"); // throw new Exception("傳入的類型有誤"); //非RuntimeException必須在出現(xiàn)的時(shí)候顯示處理 } } }
補(bǔ)充:java中異常拋出后代碼還會繼續(xù)執(zhí)行嗎?
今天遇到一個(gè)問題,在下面的代碼中,當(dāng)拋出運(yùn)行時(shí)異常后,后面的代碼還會執(zhí)行嗎,是否需要在異常后面加上return語句呢?
@Override public void registerObserver(Observer o) { if (o == null){ throw new NullPointerException("o is a null object"); return; //需要么? } this.mList.add(o); }
為了搞清楚這個(gè)問題,我編寫了幾段代碼測試了一下,結(jié)果如下:
//代碼1 public static void test() throws Exception { throw new Exception("參數(shù)越界"); System.out.println("異常后"); //編譯錯(cuò)誤,「無法訪問的語句」 }
//代碼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é):
1、若一段代碼前有異常拋出,并且這個(gè)異常沒有被捕獲,這段代碼將產(chǎn)生編譯時(shí)錯(cuò)誤「無法訪問的語句」。如代碼1;
2、若一段代碼前有異常拋出,并且這個(gè)異常被try…catch所捕獲,若此時(shí)catch語句中沒有拋出新的異常,則這段代碼能夠被執(zhí)行,否則,同第1條。如代碼2;
3、若在一個(gè)條件語句中拋出異常,則程序能被編譯,但后面的語句不會被執(zhí)行。如代碼3
另外總結(jié)一下運(yùn)行時(shí)異常與非運(yùn)行時(shí)異常的區(qū)別:
運(yùn)行時(shí)異常是RuntimeException類及其子類的異常,是非受檢異常,如NullPointerException、IndexOutOfBoundsException等。由于這類異常要么是系統(tǒng)異常,無法處理,如網(wǎng)絡(luò)問題;要么是程序邏輯錯(cuò)誤,如空指針異常;JVM必須停止運(yùn)行以改正這種錯(cuò)誤,所以運(yùn)行時(shí)異??梢圆贿M(jìn)行處理(捕獲或向上拋出,當(dāng)然也可以處理),而由JVM自行處理。Java Runtime會自動catch到程序throw的RuntimeException,然后停止線程,打印異常。
非運(yùn)行時(shí)異常是RuntimeException以外的異常,類型上都屬于Exception類及其子類,是受檢異常。非運(yùn)行時(shí)異常必須進(jìn)行處理(捕獲或向上拋出),如果不處理,程序?qū)⒊霈F(xiàn)編譯錯(cuò)誤。一般情況下,API中寫了throws的Exception都不是RuntimeException。
常見運(yùn)行時(shí)異常:
常見非運(yùn)行時(shí)異常:
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
淺談springfox-swagger原理解析與使用過程中遇到的坑
本篇文章主要介紹了淺談springfox-swagger原理解析與使用過程中遇到的坑,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-02-02java實(shí)現(xiàn)計(jì)算器加法小程序(圖形化界面)
這篇文章主要介紹了Java實(shí)現(xiàn)圖形化界面的計(jì)算器加法小程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-05-05SpringBoot Starter依賴原理與實(shí)例詳解
SpringBoot中的starter是一種非常重要的機(jī)制,能夠拋棄以前繁雜的配置,將其統(tǒng)一集成進(jìn)starter,應(yīng)用者只需要在maven中引入starter依賴,SpringBoot就能自動掃描到要加載的信息并啟動相應(yīng)的默認(rèn)配置。starter讓我們擺脫了各種依賴庫的處理,需要配置各種信息的困擾2022-09-09springboot實(shí)現(xiàn)用戶名查找用戶功能
本文主要介紹了springboot實(shí)現(xiàn)用戶名查找用戶功能,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04SpringBoot中@Transiactional注解沒有效果的解決
這篇文章主要介紹了SpringBoot中@Transiactional注解沒有效果的解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08Spring依賴注入中的@Resource與@Autowired詳解
這篇文章主要介紹了Spring依賴注入中的@Resource與@Autowired詳解,提到Spring依賴注入,大家最先想到應(yīng)該是@Resource和@Autowired,對于Spring為什么要支持兩個(gè)這么類似的注解卻未提到,屬于知其然而不知其所以然,本文就來做詳細(xì)講解,需要的朋友可以參考下2023-09-09