JAVA基礎_Java 學習之 異常

異 常

異常:就是不正常。程序在運行時出現的不正常情況。其實就是程序中出現的問題。這個問題按照面向對象思想進行描述,並封裝成了對象。因爲問題的產生有產生的原因、有問題的名稱、有問題的描述等多個屬性信息存在。當出現多屬性信息最方便的方式就是將這些信息進行封裝。異常就是java按照面向對象的思想將問題進行對象封裝。這樣就方便於操作問題以及處理問題。

出現的問題有很多種,比如角標越界,空指針等都是。就對這些問題進行分類。而且這些問題都有共性內容比如:每一個問題都有名稱,同時還有問題描述的信息,問題出現的位置,所以可以不斷的向上抽取。形成了異常體系。

——–java.lang.Throwable:

Throwable:可拋出的。
|–Error:錯誤,一般情況下,不編寫針對性的代碼進行處理,通常是jvm發生的,需要對程序進行修正。
|–Exception:異常,可以有針對性的處理方式

無論是錯誤還是異常,它們都有具體的子類體現每一個問題,它們的子類都有一個共性,就是都以父類名才作爲子類的後綴名。

這個體系中的所有類和對象都具備一個獨有的特點;就是可拋性。
可拋性的體現:就是這個體系中的類和對象都可以被throws和throw兩個關鍵字所操作。

class  ExceptionDemo{
    public static void main(String[] args) {
//      byte[] buf = new byte[1024*1024*700];//java.lang.OutOfMemoryError內存溢出錯誤
    }
}

在開發時,如果定義功能時,發現該功能會出現一些問題,應該將問題在定義功能時標示出來,這樣調用者就可以在使用這個功能的時候,預先給出處理方式。

如何標示呢?通過throws關鍵字完成,格式:throws 異常類名,異常類名…
這樣標示後,調用者,在使用該功能時,就必須要處理,否則編譯失敗。

處理方式有兩種:1、捕捉;2、拋出。
對於捕捉:java有針對性的語句塊進行處理。
try {
需要被檢測的代碼;
}
catch(異常類 變量名){
異常處理代碼;
}
fianlly{
一定會執行的代碼;
}

catch (Exception e) { //e用於接收try檢測到的異常對象。
    System.out.println("message:"+e.getMessage());//獲取的是異常的信息。
    System.out.println("toString:"+e.toString());//獲取的是異常的名字+異常的信息。
    e.printStackTrace();//打印異常在堆棧中信息;異常名稱+異常信息+異常的位置。
}

異常處理原則:功能拋出幾個異常,功能調用如果進行try處理,需要與之對應的catch處理代碼塊,這樣的處理有針對性,拋幾個就處理幾個。

特殊情況:try對應多個catch時,如果有父類的catch語句塊,一定要放在下面。

throw 和throws關鍵字的區別:


throw用於拋出異常對象,後面跟的是異常對象;throw用在函數內。
throws用於拋出異常類,後面跟的異常類名,可以跟多個,用逗號隔開。throws用在函數上。

通常情況:函數內容如果有throw,拋出異常對象,並沒有進行處理,那麼函數上一定要聲明,否則編譯失敗。但是也有特殊情況。

異常分兩種:
1:編譯時被檢查的異常,只要是Exception及其子類都是編譯時被檢測的異常。
2:運行時異常,其中Exception有一個特殊的子類RuntimeException,以及RuntimeException的子類是運行異常,也就說這個異常是編譯時不被檢查的異常。

編譯時被檢查的異常和運行時異常的區別:
編譯被檢查的異常在函數內被拋出,函數必須要聲明,否編譯失敗。
聲明的原因:是需要調用者對該異常進行處理。
運行時異常如果在函數內被拋出,在函數上不需要聲明。
不聲明的原因:不需要調用者處理,運行時異常發生,已經無法再讓程序繼續運行,所以,不讓調用處理的,直接讓程序停止,由調用者對代碼進行修正。

定義異常處理時,什麼時候定義try,什麼時候定義throws呢?
功能內部如果出現異常,如果內部可以處理,就用try;
如果功能內部處理不了,就必須聲明出來,讓調用者處理。

自定義異常:當開發時,項目中出現了java中沒有定義過的問題時,這時就需要我們按照java異常建立思想,將項目的中的特有問題也進行對象的封裝。這個異常,稱爲自定義異常。

對於除法運算,0作爲除數是不可以的。java中對這種問題用ArithmeticException類進行描述。對於這個功能,在我們項目中,除數除了不可以爲0外,還不可以爲負數。可是負數的部分java並沒有針對描述。所以我們就需要自定義這個異常。

自定義異常的步驟:


1:定義一個子類繼承Exception或RuntimeException,讓該類具備可拋性。
2:通過throw 或者throws進行操作。

異常的轉換思想:當出現的異常是調用者處理不了的,就需要將此異常轉換爲一個調用者可以處理的異常拋出。

try catch finally的幾種結合方式:
1,
try
catch
finally

這種情況,如果出現異常,並不處理,但是資源一定關閉,所以try finally集合只爲關閉資源。
記住:finally很有用,主要用戶關閉資源。無論是否發生異常,資源都必須進行關閉。
System.exit(0); //退出jvm,只有這種情況finally不執行。

當異常出現後,在子父類進行覆蓋時,有了一些新的特點:

  1. 當子類覆蓋父類的方法時,如果父類的方法拋出了異常,那麼子類的方法要麼不拋出異常要麼拋出父類異常或者該異常的子類,不能拋出其他異常。
  2. 如果父類拋出了多個異常,那麼子類在覆蓋時只能拋出父類的異常的子集。

注意:

如果父類或者接口中的方法沒有拋出過異常,那麼子類是不可以拋出異常的,如果子類的覆蓋的方法中出現了異常,只能try不能throws。
如果這個異常子類無法處理,已經影響了子類方法的具體運算,這時可以在子類方法中,通過throw拋出RuntimeException異常或者其子類,這樣,子類的方法上是不需要throws聲明的。

常見異常:

  1. 腳標越界異常(IndexOutOfBoundsException)包括數組、字符串;
    空指針異常(NullPointerException)
  2. 類型轉換異常:ClassCastException
  3. 沒有這個元素異常:NullPointerException
  4. 不支持操作異常;
    異常要儘量避免,如果避免不了,需要預先給出處理方式。比如家庭備藥,比如滅火器。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章