JAVA三種異常處理機制的具體使用
前言
異常是程序在編譯或執(zhí)行的過程中可能出現(xiàn)的問題,語法錯誤不算在異常體系
提前處理異常,程序會更加安全
一、異常體系

Error:
系統(tǒng)級別問題、JVM退出等,代碼無法控制
Exception:
Java.lang包下,稱為異常類,它表示程序本身可以處理的問題
Runtime Exception及其子類:
運行時異常,編譯階段不會報錯(如空指針,數(shù)組索引越界異常)
除Runtime Exception之外所有異常:
編譯時異常,編譯期必須處理的,否則程序不能通過編譯(如日期格式化)
二、異常示例
1.運行時異常
編譯階段不會報錯,運行時才會提示錯誤
public static void main(String[] args) {
//數(shù)組索引越界異常:ArrayIndexOutOfBoundsException
int[] arr = {1, 2, 3};
System.out.println(arr[3]);
//空指針異常:NullPointerException,直接輸出沒問題,但是調(diào)用空指針的變量功能就會報錯
String name = null;
System.out.println(name); //可以輸出
System.out.println(name.length()); //報錯
//類型轉換異常:ClassCastException
Object o = 12;
String s = (String) o;
//數(shù)學操作異常:ArithmeticException
int c = 10/0;
//數(shù)字轉換異常:NumberFormatException
String number = "a2";
Integer i = Integer.valueOf(number);
}2.編譯時異常
編譯階段就報錯,必須要處理
如下圖,日期解析異常

三、異常處理
1.默認異常處理
通常我們不對代碼可能出現(xiàn)的異常進行處理,Java就會默認處理我們的異常,如下:
默認會在出現(xiàn)異常的代碼處,自動創(chuàng)建一個異常對象:ArithmeticException
異常會從方法中出現(xiàn)的拋給調(diào)用者,調(diào)用者拋給JVM虛擬機
虛擬機收到異常對象后,先在控制臺輸出異常棧信息數(shù)據(jù)
直接從出現(xiàn)異常的地方關閉程序
2.異常處理1 & throws
添加throws ***到方法簽名
規(guī)范寫法throws Exception
將方法內(nèi)部出現(xiàn)的異常拋給本方法調(diào)用者
throws僅僅是將函數(shù)中可能出現(xiàn)的異常向調(diào)用者聲明,而自己則不具體處理。
throws聲明:如果一個方法內(nèi)部的代碼會拋出檢查異常(checked exception),而方法自己又沒有完全處理掉或并不能確定如何處理這種異常,則javac保證你必須在方法的簽名上使用throws關鍵字聲明這些可能拋出的異常,表明該方法將不對這些異常進行處理,而由該方法的調(diào)用者負責處理,否則編譯不通過。
public static void main(String[] args) throws ParseException {
parseTime("2015-10-10 10:10:10");
}
public static void parseTime(String data) throws ParseException {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-mm-dd HH:mm:ss");
Date d = sdf.parse(data);
}3.異常處理2 & try . . . catch . . .
監(jiān)視捕獲異常,用在方法內(nèi)部,可以將方法內(nèi)部出現(xiàn)的異常直接捕獲處理
發(fā)生異常的方法自己獨自完成異常處理,程序還能繼續(xù)往下執(zhí)行

public static void main(String[] args) {
parseTime("2015-10-10 10:10:10");
}
public static void parseTime(String data) {
try {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-mm-dd HH:mm:ss");
Date d = sdf.parse(data);
} catch (ParseException e) {
throw new RuntimeException(e);
}
}4.異常處理3 & 前面兩者的結合
方法將異常通過throws拋給調(diào)用者,調(diào)用者收到異常后捕獲處理。
public static void main(String[] args) {
try {
parseTime("2015-10-10 10:10:10");
System.out.println("成功");
} catch (ParseException e) {
e.printStackTrace();
System.out.println("失敗");
}
}
public static void parseTime(String data) throws ParseException {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-mm-dd HH:mm:ss");
Date d = sdf.parse(data);
}5.運行時異常的處理
可以不進行處理,編譯階段不會報錯,但建議處理,在最外層捕獲
public static void main(String[] args) {
System.out.println("開始");
try {
int d = 10/0;
} catch (Exception e) {
throw new RuntimeException(e);
}
System.out.println("結束");
}四、自定義異常
JAVA無法為所有的問題提供異常類,如果企業(yè)想通過異常的方式來管理某個業(yè)務問題,就需要自定義異常類了。
按照國際慣例,自定義的異常應該總是包含如下的構造函數(shù):
- 一個無參構造函數(shù)
- 一個帶有String參數(shù)的構造函數(shù),并傳遞給父類的構造函數(shù)。
- 一個帶有String參數(shù)和Throwable參數(shù),并都傳遞給父類構造函數(shù)。
- 一個帶有Throwable 參數(shù)的構造函數(shù),并傳遞給父類的構造函數(shù)。
注意:如果自定義異常是為了提示,在使用的時候,一定要用try..catch,不要直接用throw往外拋。
自定義編譯時異常
定義一個異常類繼承Exception
重寫構造器
public class Ageilleagaleception extends Exception{
public Ageilleagaleception (){
}
public Ageilleagaleception(String message){
super(message);
}
}在出現(xiàn)異常的地方用throw new自定義對象拋出
public static void checkAge(int age) throws Ageilleagaleception {
if(age < 0 || age > 200){
throw new Ageilleagaleception(age+"is illegal");
}else {
System.out.println("年齡正確");
}
}自定義運行時異常
定義一個類繼承RuntimeException
重寫構造器
在出現(xiàn)異常的地方用throw new自定義對象拋出
總結
程序運行時,發(fā)生的不被期望的事件,它阻止了程序按照程序員的預期正常執(zhí)行,這就是異常
異常處理不能替代簡單的測試,不要過分的細化異常
到此這篇關于JAVA三種異常處理機制的具體使用的文章就介紹到這了,更多相關JAVA 異常處理機制內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Springboot項目的Mapper中增加一個新的sql語句
本文主要介紹了Springboot項目的Mapper中增加一個新的sql語句,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2024-05-05
在MyBatis中實現(xiàn)一對多查詢和多對一查詢的方式詳解(各兩種方式)
今天通過兩種方法分別給大家介紹在MyBatis中實現(xiàn)一對多查詢和多對一查詢的方式,每種方式通過實例代碼給大家介紹的非常詳細,需要的朋友參考下吧2022-01-01

