JAVA拋出異常的三種形式詳解
一、系統(tǒng)自動拋出異常
當程序語句出現(xiàn)一些邏輯錯誤、主義錯誤或者類型轉換錯誤時,系統(tǒng)會自動拋出異常
例一
public static void main(String[] args) {
int a = 5;
int b = 0;
System.out.println( a / b);
}
運行結果,系統(tǒng)會自動拋出ArithmeticException異常
Exception in thread "main" java.lang.ArithmeticException: / by zero at io.renren.modules.sys.controller.SysUserController.main(SysUserController.java:154)
例二
public static void main(String[] args) {
String str = "abc";
System.out.println(Integer.parseInt(str));
}
運行結果,系統(tǒng)會拋出NumberFormatException異常
Exception in thread "main" java.lang.NumberFormatException: For input string: "abc" at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65) at java.lang.Integer.parseInt(Integer.java:580) at java.lang.Integer.parseInt(Integer.java:615) at io.renren.modules.sys.controller.SysUserController.main(SysUserController.java:153)
二、throw
throw是語句拋出一個異常,一般是在代碼的內部,當程序出現(xiàn)某種邏輯錯誤時同程序主動拋出某種特定類型的異常
public static void main(String[] args) {
String str = "NBA";
if (str.equals("NBA")) {
throw new NumberFormatException();
} else {
System.out.println(str);
}
}
運行結果,系統(tǒng)會拋出NumberFormatException異常
Exception in thread "main" java.lang.NumberFormatException at io.renren.modules.sys.controller.SysUserController.main(SysUserController.java:154)
三、throws
throws是方法可能會拋出一個異常(用在聲明方法時,表示該方法可能要拋出異常)
public void function() throws Exception{......}
當某個方法可能會拋出某種異常時用于throws 聲明可能拋出的異常,然后交給上層調用它的方法程序處理
public static void testThrows() throws NumberFormatException {
String str = "NBA";
System.out.println(Integer.parseInt(str));
}
public static void main(String[] args) {
try {
testThrows();
} catch (NumberFormatException e) {
e.printStackTrace();
System.out.println("非數(shù)直類型不能強制類型轉換");
}
}
運行結果
java.lang.NumberFormatException: For input string: "NBA" at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65) at java.lang.Integer.parseInt(Integer.java:580) at java.lang.Integer.parseInt(Integer.java:615) at io.renren.modules.sys.controller.SysUserController.testThrows(SysUserController.java:153) at io.renren.modules.sys.controller.SysUserController.main(SysUserController.java:158) 非數(shù)直類型不能強制類型轉換
throw與throws的比較
1、throws出現(xiàn)在方法函數(shù)頭,而throw出現(xiàn)在函數(shù)體。
2、throws表示出現(xiàn)異常的一種可能性,并不一定會發(fā)生這些異常,throw則是拋出了異常,執(zhí)行throw則一定拋出了某種異常對象。
3、兩者都是消極處理異常的方式(這里的消極并不是說這種方式不好),只是拋出或者可能拋出異常,但不會由函數(shù)去處理異常,真正的處理異常由函數(shù)的上層調用處理。
編程習慣
1、在寫程序時,對可能會出現(xiàn)異常的部分通常要用try{…}catch{…}去捕捉它并對它進行處理;
2、用try{…}catch{…}捕捉了異常之后一定要對在catch{…}中對其進行處理,那怕是最簡單的一句輸出語句,或棧輸入e.printStackTrace();
3、如果是捕捉IO輸入輸出流中的異常,一定要在try{…}catch{…}后加finally{…}把輸入輸出流關閉;
4、如果在函數(shù)體內用throw拋出了某種異常,最好要在函數(shù)名中加throws拋異常聲明,然后交給調用它的上層函數(shù)進行處理。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
JDK1.8中ConcurrentHashMap中computeIfAbsent死循環(huán)bug問題
這篇文章主要介紹了JDK1.8中ConcurrentHashMap中computeIfAbsent死循環(huán)bug,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-08-08
java調用webservice接口,并解析返回參數(shù)問題
這篇文章主要介紹了java調用webservice接口,并解析返回參數(shù)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07
簡析Java中的util.concurrent.Future接口
這篇文章主要介紹了簡析Java中的util.concurrent.Future接口,作者把future歸結為在未來得到目標對象的占位符,需要的朋友可以參考下2015-07-07

