您好,登錄后才能下訂單哦!
這篇文章給大家介紹Java中怎么實現異常處理,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
在Java語言中,將程序執行中發生的不正常情況稱為“異常”。(開發過程中的語法錯誤和邏輯錯誤不是異常)
Java程序在執行過程中所發生的異常事件可分為兩類:
Error
: Java虛擬機無法解決的嚴重問題。如:JVM系統內部錯誤、資源耗盡等嚴重情況。比如: StackOverflowError
和OOM。一般不編寫針對性的代碼進行處理。
Exception
:其它因編程錯誤或偶然的外在因素導致的一般性問題,可以使用針對性的代碼進行處理。如:
空指針訪問
試圖讀取不存在的文件
網絡連接中斷
數組角標越界
異常的體系結構 * java.lang.Throwable * |-----java.lang.Error:一般不編寫針對性的代碼進行處理。 * |-----java.lang.Exception:可以進行異常的處理 * |------編譯時異常(checked)不會生成字節碼文件 * |-----IOException * |-----FileNotFoundException * |-----ClassNotFoundException * |------運行時異常(unchecked,RuntimeException) * |-----NullPointerException//空指針異常 * |-----ArrayIndexOutOfBoundsException//數組角標越界 * |-----ClassCastException//類型轉化異常 * |-----NumberFormatException//編碼格式異常 * |-----InputMismatchException//輸入不匹配 * |-----ArithmeticException//算術異常
java中異常類的繼承關系
編譯時異常:執行 javac.exe
命令時,可能出現的異常:
指編譯器要求必須處置的異常。即程序在運行時由于外界因素造成的一般性異常。編譯器要求Java程序必須捕獲或聲明所有編譯時異常對于這類異常,如果程序不處理,可能會帶來意想不到的結果。
運行時異常:執行 java.exe
命令時,出現的異常:
指編譯器不要求強制處置的異常。一般是指編程時的邏輯錯誤,是程序員應該積極避免其出現的異常。 java. lang. Runtime Exception
類及它的子類都是運行時異常。對于這類異常,可以不作處理,因為這類異常很普遍,若全處理可能會對程序的可讀性和運行效率產生影響。
//******************以下是運行時異常*************************** //ArithmeticException @Test public void test6(){ int a = 10; int b = 0; System.out.println(a / b); } //InputMismatchException @Test public void test5(){ Scanner scanner = new Scanner(System.in); int score = scanner.nextInt(); System.out.println(score); scanner.close(); } //NumberFormatException @Test public void test4(){ String str = "123"; str = "abc"; int num = Integer.parseInt(str); } //ClassCastException @Test public void test3(){ Object obj = new Date(); String str = (String)obj; } //IndexOutOfBoundsException @Test public void test2(){ //ArrayIndexOutOfBoundsException // int[] arr = new int[10]; // System.out.println(arr[10]); //StringIndexOutOfBoundsException String str = "abc"; System.out.println(str.charAt(3)); } //NullPointerException @Test public void test1(){ // int[] arr = null; // System.out.println(arr[3]); String str = "abc"; str = null; System.out.println(str.charAt(0)); } //******************以下是編譯時異常*************************** @Test public void test7(){ // File file = new File("hello.txt"); // FileInputStream fis = new FileInputStream(file); // // int data = fis.read(); // while(data != -1){ // System.out.print((char)data); // data = fis.read(); // } // // fis.close(); }
**過程一:"拋"**程序在正常執行的過程中,一旦出現異常,就會在異常代碼處生成一個對應異常類的對象。并將此對象拋出。一旦拋出對象以后,其后的代碼就不再執行。
關于異常對象的產生:
系統自動生成的異常對象
手動的生成一個異常對象,并拋出(throw
)
**過程二:"抓"**可以理解為異常的處理方式:① try-catch-finally
② throws
try{ //可能出現異常的代碼 }catch(異常類型1 變量名1){ //處理異常的方式1 }catch(異常類型2 變量名2){ //處理異常的方式2 }catch(異常類型3 變量名3){ //處理異常的方式3 } .... finally{ //一定會執行的代碼 }
使用說明:
finally
是可選的。
使用 try
將可能出現異常代碼包裝起來,在執行過程中,一旦出現異常,就會生成一個對應異常類的對象,根據此對象的類型,去 catch
中進行匹配
一旦 try
中的異常對象匹配到某一個 catch
時,就進入 catch
中進行異常的處理。一旦處理完成,就跳出當前的 try-catch
結構(在沒寫 finally
的情況。繼續執行其后的代碼)
catch
中的異常類型如果沒子父類關系,則誰聲明在上,誰聲明在下無所謂;catch
中的異常類型如果滿足子父類關系,則要求子類一定聲明在父類的上面。否則會報錯
常用的異常對象處理的方式: ① String getMessage()
② printStackTrace()
在try
結構中聲明的變量,再出了 try
結構以后,就不能再被調用
try-catch-finally
結構可以嵌套
如何看待代碼中的編譯時異常和運行時異常?
使用 try-catch-finally
處理編譯時異常,是得程序在編譯時就不再報錯,但是運行時仍可能報錯。相當于我們使用 try-catch-finally
將一個編譯時可能出現的異常,延遲到運行時出現。
開發中,由于運行時異常比較常見,所以我們通常就不針對運行時異常編寫 try-catch-finally
了。但是針對于編譯時異常,一定要考慮異常的處理。
finally
是可選的
finally
中聲明的是一定會被執行的代碼。即使catch中又出現異常了,try
中包含 return
語句,或者catch
中 return
包含語句等情況,finally
中的代碼也會被執行。
像數據庫連接、輸入輸出流、網絡編程Socket等資源,JVM是不能自動的回收的,我們需要自己手動的進行資源的釋放。此時的資源釋放的代碼,就需要聲明在 finally
中。
throws + 異常類型
寫在方法的聲明處。指明此方法執行時,可能會拋出的異常類型。 一旦當方法體執行時,出現異常,仍會在異常代碼處生成一個異常類的對象,此對象滿足 throws
后異常類型時,就會被拋出。異常代碼后續的代碼,就不再執行!
try-catch-finally
真正的將異常給處理掉了。 throws
的方式只是將異常拋給了方法的調用者。并沒真正將異常處理掉。
如果父類中被重寫的方法沒 throws
方式處理異常,則子類重寫的方法也不能使用 throws
,意味著如果子類重寫的方法中異常,必須使用 try-catch-finally
方式處理。
執行的方法a中,先后又調用了另外的幾個方法,這幾個方法是遞進關系執行的。我們建議這幾個方法使用throws
的方式進行處理。而執行的方法a可以考慮使用 try-catch-finally
方式進行處理。
補充: 方法重寫的規則之一: 子類重寫的方法拋出的異常類型不大于父類被重寫的方法拋出的異常類型
在程序執行中,除了自動拋出異常對象的情況之外,我們還可以手動的 throw
一個異常類的對象。
throw
和 throws
區別: throw
表示拋出一個異常類的對象,生成異常對象的過程。聲明在方法體內。 throws
屬于異常處理的一種方式,聲明在方法的聲明處。
class Student{ private int id; public void regist(int id) throws Exception { if(id > 0){ this.id = id; }else{ //手動拋出異常對象 // throw new RuntimeException("您輸入的數據非法!"); // throw new Exception("您輸入的數據非法!"); throw new MyException("不能輸入負數"); } } @Override public String toString() { return "Student [id=" + id + "]"; } }
繼承于現的異常結構:RuntimeException 、Exception
提供全局常量:serialVersionUID
(對類的唯一標識)
提供重載的構造器
public class MyException extends Exception{ static final long serialVersionUID = -7034897193246939L; public MyException(){ } public MyException(String msg){ super(msg); } }
關于Java中怎么實現異常處理就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。