java 異常之手動拋出與自動拋出的實例講解
java異常處理機(jī)制的兩類
1、抓:異常的處理,有兩種方式
① try-catch-finally
② throws
2、拋:
① 自動拋出
可以理解為所有沒有使用throw關(guān)鍵字的異常處理都是自動拋出,由jvm進(jìn)行判斷和拋出。
②手動拋出
throw + 異常類的對象
》異常類可以是現(xiàn)成的,也可以是自己創(chuàng)建的異常類,
拋出異類的類型:若是RuntimException,可以不用顯示處理。
若是一個Exception,必須要顯示的處理。
/*
*1.手動拋出一個異常的例子
*/
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;
}
//比較兩個圓的半徑誰大
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 {
//因為在這里返回聲明都不適合,手動的拋出一個異常
//運行時異常可以不用顯示處理,在運行的時候,拋出。
throw new RuntimeException("傳入的類型有誤");
// throw new Exception("傳入的類型有誤");
//非RuntimeException必須在出現(xiàn)的時候顯示處理
}
}
}
補(bǔ)充:java中異常拋出后代碼還會繼續(xù)執(zhí)行嗎?
今天遇到一個問題,在下面的代碼中,當(dāng)拋出運行時異常后,后面的代碼還會執(zhí)行嗎,是否需要在異常后面加上return語句呢?
@Override
public void registerObserver(Observer o) {
if (o == null){
throw new NullPointerException("o is a null object");
return; //需要么?
}
this.mList.add(o);
}
為了搞清楚這個問題,我編寫了幾段代碼測試了一下,結(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é):
1、若一段代碼前有異常拋出,并且這個異常沒有被捕獲,這段代碼將產(chǎn)生編譯時錯誤「無法訪問的語句」。如代碼1;
2、若一段代碼前有異常拋出,并且這個異常被try…catch所捕獲,若此時catch語句中沒有拋出新的異常,則這段代碼能夠被執(zhí)行,否則,同第1條。如代碼2;
3、若在一個條件語句中拋出異常,則程序能被編譯,但后面的語句不會被執(zhí)行。如代碼3
另外總結(jié)一下運行時異常與非運行時異常的區(qū)別:
運行時異常是RuntimeException類及其子類的異常,是非受檢異常,如NullPointerException、IndexOutOfBoundsException等。由于這類異常要么是系統(tǒng)異常,無法處理,如網(wǎng)絡(luò)問題;要么是程序邏輯錯誤,如空指針異常;JVM必須停止運行以改正這種錯誤,所以運行時異??梢圆贿M(jìn)行處理(捕獲或向上拋出,當(dāng)然也可以處理),而由JVM自行處理。Java Runtime會自動catch到程序throw的RuntimeException,然后停止線程,打印異常。
非運行時異常是RuntimeException以外的異常,類型上都屬于Exception類及其子類,是受檢異常。非運行時異常必須進(jìn)行處理(捕獲或向上拋出),如果不處理,程序?qū)⒊霈F(xiàn)編譯錯誤。一般情況下,API中寫了throws的Exception都不是RuntimeException。
常見運行時異常:

常見非運行時異常:

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
淺談springfox-swagger原理解析與使用過程中遇到的坑
本篇文章主要介紹了淺談springfox-swagger原理解析與使用過程中遇到的坑,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-02-02
SpringBoot中@Transiactional注解沒有效果的解決
這篇文章主要介紹了SpringBoot中@Transiactional注解沒有效果的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08
Spring依賴注入中的@Resource與@Autowired詳解
這篇文章主要介紹了Spring依賴注入中的@Resource與@Autowired詳解,提到Spring依賴注入,大家最先想到應(yīng)該是@Resource和@Autowired,對于Spring為什么要支持兩個這么類似的注解卻未提到,屬于知其然而不知其所以然,本文就來做詳細(xì)講解,需要的朋友可以參考下2023-09-09

