国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

Java異常處理實例分析

2019-11-26 15:12:52
字體:
來源:轉載
供稿:網友

本文實例講述了Java異常處理的用法。分享給大家供大家參考。具體分析如下:

Java的異常處理機制可以幫助我們避開或者處理程序可能發生的錯誤,從而使得程序在遇到一些可恢復的錯誤的時候不會意外終止,而是去處理這些錯誤,也使得我們在寫程序的時候不必寫大量的代碼來檢查錯誤情況,增強了代碼的可讀性和邏輯性。在Java中,異常代表一個錯誤的實體對象。

異常可分為兩類;一類是嚴重錯誤,如硬件錯誤、內存不足等,它們對應著java.lang包下的Error類及其子類。通常這類錯誤程序自身是無法恢復的,需要中斷程序的執行;另一類是非嚴重的錯誤,如用戶輸入了非法數據,被0除等,它們對應著java.lang包中的Exception類及其子類,這種錯誤一般可以恢復,不影響程序的運行。
我們可以用try, catch,finally關鍵字來捕捉異常。

1、try, catch

將可能會發生異常的語句放到try{}塊中,然后在catch{}語句塊中捕捉即可。如被0除異常:

public class SimpleDemo {   //除法運算   public static int devision(int a,int b)   {     return a / b;   }      public static void main(String[] args)   {     try      {       //5除以0       SimpleDemo.devision(5,0);       System.out.println("Exception");     }      catch (Exception e)      {       e.printStackTrace();     }          System.out.println("Finish");   } }

執行結果:

可以看到,Finish被打印了出來,說明程序并沒有因為發生了被0除的錯誤而終止。
同時我們也發現,發生異常的SimpleDemo.devision()下面的System.out.println語句并沒有被執行。一旦異常發生,程序就會從當前執行的位置跳出,而不會執行異常后面的語句。

2、finally

finally語句塊中的語句無論異常有沒有發生都會被執行。
有人可能會問,既然finally塊中的語句無論異常有沒有發生都會被執行,那么這個finally到底有什么實際作用呢?我不用finally直接寫在外面不行么?
如上例,我們在catch語句塊中加入一個return:

public class SimpleDemo {   //除法運算   public static int division(int a,int b)   {     return a / b;   }   public static void main(String[] args)   {     try      {       //5除以0       SimpleDemo.division(5,0);       System.out.println("Exception");     }      catch (Exception e)      {       e.printStackTrace();       return; //main函數返回     }     finally     {       System.out.println("Finally");     }     System.out.println("Finish");   } }

這時候,finally外面的Finish沒有被打印,而finally塊內部的Finally則被打印了出來。

finally在實際開發中非常有用。例如我們打開了一個數據庫,在數據庫讀寫數據的時候發生了異常,那么這時候就應該關閉數據庫的連接,并釋放相應的資源。這時候把釋放資源的代碼寫在 finally塊中是最合適不過的了。

但要注意的是,finally塊在一種情況下是不會被執行的。如果程序在執行到finally塊前退出了,如調用System.exit()方法,則 finally塊也就得不到執行的機會了。

3、丟出異常

如果在一個方法中會有異常發生,但我們不想在方法中直接去處理這個異常,而是想讓方法的調用者去處理,則可以使用throws關鍵字聲明這個方法來丟出異常。這在Sun給我們提供的API函數中非常常見,如java.io.Reader中的read方法被聲明為丟出一個IOException異常:

public int read(char[] cbuf)     throws IOException

這時候我們在調用read方法時就必須將其放在try語句塊中進行異常捕捉,否則編譯器就會報錯,強制我們進行異常捕捉。
當然,如果我們確實不想在調用read的時候處理異常,那么也可以把調用read方法的方法聲明為throws IOException,這樣異常就會再次被丟出。如果我們在main函數中聲明丟出Exception異常,那么異常信息最終會被JVM捕獲處理,而JVM的處理結果是,打印出異常信息,然后終止程序的運行。

4、異常處理的構架

所有的異常類都是從Exception類中派生而來的。這意味著,如果我們不確定會發生什么類型的異常,可以直接在catch中聲明一個Exception對象,就能捕獲到所有的Exception類及其子類的異常了。但要注意catch書寫的順序。如果在一個try后面有多個catch且第一個catch中聲明的是Exception對象,那么這個異常就會直接被第一個catch處理,后面的catch都無法捕獲到這個異常。這種錯誤在編譯的時候就會以產生錯誤。如下例:

public class CatchDemo {   //除法運算   public static int division(int a,int b)   {     return a / b;   }   public static void main(String[] args)   {     try     {       CatchDemo.division(4,0);     }     catch(Exception e)     {       System.out.println("Exception Class");     }     catch(ArithmeticException e)     {       System.out.println("ArithmeticException Class");     }   } }

編譯器輸出  ArithmeticException已經被捕獲了,意思就是說上面的Exception已經捕獲了這個異常,無須重復捕獲。

如果把這兩個catch反過來會怎樣呢?

public class CatchDemo {   //除法運算   public static int division(int a,int b)   {     return a / b;   }   public static void main(String[] args)   {     try     {       CatchDemo.division(4,0);     }     catch(ArithmeticException e)     {       System.out.println("ArithmeticException Class");    }     catch(Exception e)     {       System.out.println("Exception Class");    }   } }

這時候我們發現,代碼通過了編譯,且執行的結果是 ArithmeticException捕獲了這個異常,而后面的catch則沒有捕獲到。

希望本文所述對大家的java程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 博白县| 元江| 循化| 资源县| 抚顺市| 龙海市| 五莲县| 浪卡子县| 玉门市| 古丈县| 龙川县| 古蔺县| 海城市| 晋州市| 遵化市| 石渠县| 淮安市| 五指山市| 广灵县| 五指山市| 德令哈市| 乡城县| 滨州市| 社旗县| 永城市| 额尔古纳市| 江陵县| 资阳市| 乐至县| 大连市| 沭阳县| 锡林郭勒盟| 昭平县| 嘉善县| 巴马| 枣阳市| 双城市| 商城县| 柘荣县| 长沙市| 安溪县|