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,直接輸出沒問題,但是調用空指針的變量功能就會報錯 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)的拋給調用者,調用者拋給JVM虛擬機
虛擬機收到異常對象后,先在控制臺輸出異常棧信息數(shù)據(jù)
直接從出現(xiàn)異常的地方關閉程序
2.異常處理1 & throws
添加throws ***到方法簽名
規(guī)范寫法throws Exception
將方法內部出現(xiàn)的異常拋給本方法調用者
throws僅僅是將函數(shù)中可能出現(xiàn)的異常向調用者聲明,而自己則不具體處理。
throws聲明:如果一個方法內部的代碼會拋出檢查異常(checked exception),而方法自己又沒有完全處理掉或并不能確定如何處理這種異常,則javac保證你必須在方法的簽名上使用throws關鍵字聲明這些可能拋出的異常,表明該方法將不對這些異常進行處理,而由該方法的調用者負責處理,否則編譯不通過。
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)視捕獲異常,用在方法內部,可以將方法內部出現(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拋給調用者,調用者收到異常后捕獲處理。
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 異常處理機制內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Springboot項目的Mapper中增加一個新的sql語句
本文主要介紹了Springboot項目的Mapper中增加一個新的sql語句,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2024-05-05在MyBatis中實現(xiàn)一對多查詢和多對一查詢的方式詳解(各兩種方式)
今天通過兩種方法分別給大家介紹在MyBatis中實現(xiàn)一對多查詢和多對一查詢的方式,每種方式通過實例代碼給大家介紹的非常詳細,需要的朋友參考下吧2022-01-01