java 異常之手動(dòng)拋出與自動(dòng)拋出的實(shí)例講解
java異常處理機(jī)制的兩類
1、抓:異常的處理,有兩種方式
① try-catch-finally
② throws
2、拋:
① 自動(dòng)拋出
可以理解為所有沒(méi)有使用throw關(guān)鍵字的異常處理都是自動(dòng)拋出,由jvm進(jìn)行判斷和拋出。
②手動(dòng)拋出
throw + 異常類的對(duì)象
》異常類可以是現(xiàn)成的,也可以是自己創(chuàng)建的異常類,
拋出異類的類型:若是RuntimException,可以不用顯示處理。
若是一個(gè)Exception,必須要顯示的處理。
/*
*1.手動(dòng)拋出一個(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è)圓的半徑誰(shuí)大
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)樵谶@里返回聲明都不適合,手動(dòng)的拋出一個(gè)異常
//運(yùn)行時(shí)異??梢圆挥蔑@示處理,在運(yùn)行的時(shí)候,拋出。
throw new RuntimeException("傳入的類型有誤");
// throw new Exception("傳入的類型有誤");
//非RuntimeException必須在出現(xiàn)的時(shí)候顯示處理
}
}
}
補(bǔ)充:java中異常拋出后代碼還會(huì)繼續(xù)執(zhí)行嗎?
今天遇到一個(gè)問(wèn)題,在下面的代碼中,當(dāng)拋出運(yùn)行時(shí)異常后,后面的代碼還會(huì)執(zhí)行嗎,是否需要在異常后面加上return語(yǔ)句呢?
@Override
public void registerObserver(Observer o) {
if (o == null){
throw new NullPointerException("o is a null object");
return; //需要么?
}
this.mList.add(o);
}
為了搞清楚這個(gè)問(wèn)題,我編寫了幾段代碼測(cè)試了一下,結(jié)果如下:
//代碼1
public static void test() throws Exception {
throw new Exception("參數(shù)越界");
System.out.println("異常后"); //編譯錯(cuò)誤,「無(wú)法訪問(wèn)的語(yǔ)句」
}
//代碼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("異常后"); //拋出異常,不會(huì)執(zhí)行
總結(jié):
1、若一段代碼前有異常拋出,并且這個(gè)異常沒(méi)有被捕獲,這段代碼將產(chǎn)生編譯時(shí)錯(cuò)誤「無(wú)法訪問(wèn)的語(yǔ)句」。如代碼1;
2、若一段代碼前有異常拋出,并且這個(gè)異常被try…catch所捕獲,若此時(shí)catch語(yǔ)句中沒(méi)有拋出新的異常,則這段代碼能夠被執(zhí)行,否則,同第1條。如代碼2;
3、若在一個(gè)條件語(yǔ)句中拋出異常,則程序能被編譯,但后面的語(yǔ)句不會(huì)被執(zhí)行。如代碼3
另外總結(jié)一下運(yùn)行時(shí)異常與非運(yùn)行時(shí)異常的區(qū)別:
運(yùn)行時(shí)異常是RuntimeException類及其子類的異常,是非受檢異常,如NullPointerException、IndexOutOfBoundsException等。由于這類異常要么是系統(tǒng)異常,無(wú)法處理,如網(wǎng)絡(luò)問(wèn)題;要么是程序邏輯錯(cuò)誤,如空指針異常;JVM必須停止運(yùn)行以改正這種錯(cuò)誤,所以運(yùn)行時(shí)異??梢圆贿M(jìn)行處理(捕獲或向上拋出,當(dāng)然也可以處理),而由JVM自行處理。Java Runtime會(huì)自動(dòng)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)文章
Reactor中的onErrorContinue?和?onErrorResume
這篇文章主要介紹了Reactor中的onErrorContinue?和?onErrorResume,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的朋友可以參考一下2022-09-09
mybatis二級(jí)緩存的實(shí)現(xiàn)代碼
這篇文章主要為大家詳細(xì)介紹了mybatis二級(jí)緩存的實(shí)現(xiàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10
Java實(shí)現(xiàn)字符串與字節(jié)數(shù)組之間相互轉(zhuǎn)換
在Java編程中,字符串(String)和字節(jié)數(shù)組(byte[])之間的相互轉(zhuǎn)換是非常常見的操作,這種轉(zhuǎn)換在網(wǎng)絡(luò)編程、文件處理、加密解密等場(chǎng)景中尤為重要,本文將詳細(xì)介紹如何在Java中實(shí)現(xiàn)字符串與字節(jié)數(shù)組之間的相互轉(zhuǎn)換,需要的朋友可以參考下2025-02-02
java基于包結(jié)構(gòu)的請(qǐng)求路由實(shí)現(xiàn)實(shí)例分享
基于包結(jié)構(gòu)的請(qǐng)求路由簡(jiǎn)單實(shí)現(xiàn)實(shí)例分享,大家參考使用吧2013-12-12
MyBatis-Plus與PageHelper依賴的jsqlparser庫(kù)沖突
在升級(jí)SpringBoot到3.x版本的同時(shí),升級(jí)MyBatis-Plus后發(fā)現(xiàn)PageHelper無(wú)法使用,原因是MyBatis-Plus和PageHelper都依賴jsqlparser庫(kù),且PageHelper要求特定版本的jsqlparser,解決方法是在項(xiàng)目中排除這兩個(gè)庫(kù)的jsqlparser依賴,直接引用jsqlparser4.7版本2024-10-10
Java程序執(zhí)行時(shí)間的2種簡(jiǎn)單方法
這篇文章介紹了Java程序執(zhí)行時(shí)間的2種簡(jiǎn)單方法,有需要的朋友可以參考一下2013-09-09

