❶ java中exception的處理
早期的編程語言(比如C語言)沒有異常處理,通常是遇到錯誤返回一個特殊的值或設定一個標志,並以此判斷是不是有錯誤產生。隨著系統規模的不斷擴大,這種錯誤處理已經成為創建大型可維護程序的障礙了。
於是在一些語言中出現了異常處理機制,比如在Basic中的異常處理語句「on error goto」,而Java則在C++基礎上建立了新的異常處理機制。
Java通過面向對象的方法進行異常處理,把各種不同的異常進行分類,並提供了良好的介面。這種機制為復雜程序提供了強有力的控制方式。同時這些異常代碼與「常規」代碼分離,增強了程序的可讀性,編寫程序時也顯得更靈活。
Java中的異常類
在Java中,每個異常都是一個對象,它是Throwable類或其它子類的實例。當一個方法出現異常後便拋出一個異常對象,該對象中包含有異常信息,調用這個對象的方法可以捕獲到這個異常並進行處理。
Throwable類有兩個標准子類:java.lang.Error和java.lang.Exception,即錯誤和異常。錯誤:Error類,一般是指虛擬機相關的問題,如系統崩潰、虛擬機出錯誤、動態鏈接失敗等,這一類錯誤無法恢復或不可能捕獲,將導致應用程序中斷。
異常:Exception類,則是指一些可以被捕獲且可能恢復的異常情況,如數組下標越界Array,Index,OutOf,Bounds,Excepton。數字被零除產生異常:ArithmeticException 、輸入/輸出異常:IOException等。
提示:Java編譯器要求Java程序必須捕獲或聲明所有非運行時的異常,如:FileNotFoundException、IOException等。因為,對於這類異常來說,如果程序不進行處理,可能會帶來意想不到的結果。但運行時出現異常可以不做處理,因為這類異常很普遍,全部處理可能對程序的可讀性和運行效率產生影響。
Java異常處理形式,Java的異常處理是通過5個關鍵詞來實現的:try、catch、throw、throws和finally。一般情況下是用try來執行一段程序,如果出現異常,系統會拋出(throws)一個異常,這時候你可以通過它的類型來捕捉(catch)它,或最後(finally)由預設處理器來處理。
下面是Java異常處理程序的基本形式: try //執行時程序塊 catch ExceptionType1e //對ExceptionType1的處理 catch ExceptionType2e //對ExceptionType2的處理 throw e //再拋出這個「異常」 finally try程序塊和catch語句:遇到一個try語句,「異常」的框架就放到堆棧上面,直到所有的try塊內的語句都完成。如果下一級的try語句沒有對某種「異常」進行處理,堆棧就會展開,直到遇到有處理這種「異常」的try語句。 在try程序後面,應包含一個catch子句來指定你想要捕捉的「異常」的類型。提示:捕獲異常的第一步就是用try … 選定你要捕獲異常的范圍,在執行時,括弧內的代碼會產生異常對象並被拋出。然後你就可以用catch塊來處理異常了。 throw語句和throws語句:throw語句用來明確地拋出一個「異常」。首先,你必須得到一個Throwable類或其它子類產生的實例句柄,通過參數傳到catch子句,或者用new語句來創建一個實例。 下面是throw語句的通常形式: throw ThrowableInstance,提示:執行throw語句後,運行流程將立即停止,throw的下一條語句也將暫停執行。這里new運算符用於創建一個Throwable類的實例,在後文的面向對象編程一文中將詳細講解。 throws語句用來標明一個成員函數可能拋出的各種「異常」。對大多數Exception子類來說,Java編譯器會強迫你聲明在一個成員函數中拋出的「異常」的類型。如果「異常」的類型是Error或RuntimeException,或它們的子類,這個規則不起作用。如果你想明確地拋出一個RuntimeException,你必須用throws語句來聲明它的類型。 提示:當然,你可能對上面的說明不是很明白,不過不要緊,編譯運行下面的Java程序(已經為你做了詳細的注釋)你會理解很多! 現在我們用下面的常式來說明問題: class ThrowsDemo //類名,相應的java源文件應該保存成: ThrowsDemo.javastatic void procere throws IllegalAccessException //throws語句 //拋出IllegalAccessException類型的異常System.out.println ″inside procere″ //輸出文本信息,以說明是在執行procere方法時拋出了異常throw new IllegalAccessException ″demo″ //新生成一個Throwable類實例,然後拋出異常 public static void main String args //main 方法開始,程序從此處執行 try //try語句塊開始procere //調用procere方法,該方法將Throw(拋出)異常信息 catch IllegalAccessException e //處理IllegalAccessException類型的異常, catch語句塊System.out.println ″caught ″ + e 編程並執行程序,其過程如下: E \javacode\exception>java ThrowsDemoinside procerecaught java.lang.IllegalAccessException demo提示:如上面的代碼所示,我們用了一個完整的程序來說明在Java程序中如何使用try…catch…throw等語句。Try … 里產生的異常被捕獲了下來,然後在catch塊里進行處理(這里只是輸出異常信息)。 throws IllegalAccessException標明程序將拋出一個IllegalAccessException類型的異常。IllegalAccessExceptione生成一個異常對象,然後用System.out.println輸出異常信息。 finally語句,有時為了確保一段代碼不管發生什麼異常都要被執行,可以使用關鍵詞finally來標出這樣一段代碼。一個成員函數返回到調用它的成員函數,或者通過一個沒捕捉到的異常,或者通過一個明確的return語句,finally子句總是恰好在成員函數返回前執行。 下面我們以一個比較完整的異常處理程序來說明上面所述的各種異常處理語句的使用問題: class ExceptionDemo //異常使用示例,保存為ExceptionDemo.javastatic void procA try System.out.println ″inside procA″ throw new RuntimeException ″demo″ //拋出異常finally System.out.println ″procA's finally″ //注意:不管發生什麼等會執行!!static void procB try System.out.println ″inside procB″ return //返回,實際上是在finally語句執行完後才返回finally System.out.println ″procB's finally″ public static void main String args try procA catch Exception e System.out.println ″catch ″+e procB提示:在上面的完整程序中,finally後的大括弧內的代碼是任何情況下都會執行的。另外,在procB中,return 語句並沒有立即返回,這一點應該特別注意。你可以親自動手,執行上面的程序試試(編譯和執行類似於上例)。 到目前為止,關於Java的流程式控制制已經完全講完了。要真正理解並掌握它們只有經過大量的練習。而好的方法就是修改上面的每一個程序,讓它們實現你想要的功能,並在此基本上理解Java的流程式控制制。 而要寫好Java程序,熟悉使用Java的流程式控制制和異常處理是非常關鍵的。
希望對你能有所幫助。
❷ Java中Exception是什麼
Exception是JAVA異常類 是Throwable的子類(Error也是她的子類,Error是比較嚴重的錯誤)
異常分為普通異常和運行時異常,運行時異常我們可以不處理,可以讓虛擬機來管。
普通異常我們必須捕獲(try{}catch(Exception e){}finally{})
❸ Java中Exception是什麼
Exception是JAVA異常類
是Throwable的子類(Error也是她的子類,Error是比較嚴重的錯誤)
異常分為普通異常和運行時異常,運行時異常我們可以不處理,可以讓虛擬機來管。
普通異常我們必須捕獲(try{}catch(Exception
e){}finally{})
❹ java中5種常見的異常(Exception)是哪些
Java.lang.NullPointerException
這個異常大家肯定都經常碰到,異常的解釋是"程序遇上了空指針",簡單地說就是調用了未經初始化的對象或者是不存在的對象,這個錯誤經常出現在創建圖片,調用數組這些操作中,比如圖片未經初始化,或者圖片創建時的路徑錯誤等等。對數組操作中出現空指針,很多情況下是一些剛開始學習編程的朋友常犯的錯誤,即把數組的初始化和數組元素的初始化混淆起來了。數組的初始化是對數組分配需要的空間,而初始化後的數組,其中的元素並沒有實例化,依然是空的,所以還需要對每個元素都進行初始化(假如要調用的話)
2. java.lang.ClassNotFoundException
這個異常是很多原本在JB等開發環境中開發的程序員,把JB下的程序包放在WTk下編譯經常出現的問題,異常的解釋是"指定的類不存在",這里主要考慮一下類的名稱和路徑是否正確即可,假如是在JB下做的程序包,一般都是默認加上Package的,所以轉到WTK下後要注重把Package的路徑加上。
3. java.lang.ArithmeticException
這個異常的解釋是"數學運算異常",比如程序中出現了除以零這樣的運算就會出這樣的異常,對這種異常,大家就要好好檢查一下自己程序中涉及到數學運算的地方,公式是不是有不妥了。
4. java.lang.
這個異常相信很多朋友也經常碰到過,異常的解釋是"數組下標越界",現在程序中大多都有對數組的操作,因此在調用數組的時候一定要認真檢查,看自己調用的下標是不是超出了數組的范圍,一般來說,顯示(即直接用常數當下標)調用不太輕易出這樣的錯,但隱式(即用變數表示下標)調用就經常出錯了,還有一種情況,是程序中定義的數組的長度是通過某些特定方法決定的,不是事先聲明的,這個時候,最好先查看一下數組的length,以免出現這個異常。
5. java.lang.IllegalAccessException
這個異常的解釋是"沒有訪問許可權",當應用程序要調用一個類,但當前的方法即沒有對該類的訪問許可權便會出現這個異常。對程序中用了Package的情況下要注重這個異常。
❺ java中自定義異常為何要繼承exception類
java.lang.Exception類是Java中所有異常的直接或間接父類。即Exception類是所有異常的根類。
1、異常的分類:
① 非運行時異常(Checked Exception)
② 運行時異常(Runtime Exception/Unchecked Exception)
public class Exception
extends Throwable
Exception 類及其子類是 Throwable 的一種形式,它指出了合理的應用程序想要捕獲的條件。
public class RuntimeException
extends Exception
RuntimeException 是那些可能在 Java 虛擬機正常運行期間拋出的異常的超類。
可能在執行方法期間拋出但未被捕獲的 RuntimeException 的任何子類都無需在 throws 子句中進行聲明。
a) RuntimeException類直接繼承自Exception類,稱為運行時異常。Java中所有的運行時異常都直接或間接的繼承自RuntimeException.
Java中所有的異常類都直接或間接的繼承自Exception。
2、異常的處理:
對應非運行時異常,必須對其進行處理。處理方式有兩種:
使用try…catch…finally語句塊進行捕獲
在產生異常的方法所在的方法聲明throws Exception
對於運行時異常,可以不對其進行處理,也可以對其進行處理。一般情況下都不對其進行處理。
3、捕獲異常:
try {
FileInputStream fs = new FileInputStream("D:/temp/a.txt");
} catch (FileNotFoundException e) {
System.out.println("catch...");
e.printStackTrace();
} finally{
System.out.println("finally...");
}
4、拋出和捕獲異常:
4.1、把異常交給JVM處理:
public class ExceptionTest {
public static void execute() throws Exception {
System.out.println("execute...");
throw new Exception();
}
public static void main(String[] args) throws Exception {
execute();
}
}
4.2、或者使用try catch語句塊捕獲異常:
public class ExceptionTest {
public static void execute() throws Exception {
System.out.println("execute...");
throw new Exception();
}
public static void main(String[] args) {
try {
execute();
} catch (Exception e1) {
e1.printStackTrace();
}
}
}
5、自定義異常:
自定義異常通常是定義一個繼承自Exception類的子類。一般情況下我們都會直接繼承自Exception類,而不會繼承某個運行時的異常類。
5.1、創建自定義異常:
public class MyException extends Exception{
public MyException(){
super();
}
public MyException(String msg){
super(msg);
}
}
5.2、在類中使用異常:
public class ExceptionTest {
public static void execute(String a) throws MyException {
System.out.println("execute...");
if("true".equals(a)){
throw new MyException("參數不能為 true");
}
}
}
5.3、捕獲自定義異常:
public static void main(String[] args) throws MyException {
execute("true");
}
6、異常使用注意事項:
當使用多個catch語句塊來捕獲異常時,需要將父類的catch語句塊放到子類型的catch塊之後,這樣才能保證後續的catch可能被執行,否則子類型的catch將永遠無法到達,Java編譯器會報編譯錯誤。
如果try語句塊中存在return語句,那麼首先會執行finally語句塊中的代碼,然後才返回。
如果try語句塊中存在System.exit(0)語句,那麼久不會執行finally語句塊的代碼了,因為System.exit(0)會終止當前運行的JVM。程序在JVM終止前結束執行。
❻ Java中Exception與RuntimeException有什麼異同
說到Exception和RuntimeException的區別,首先看一段代碼,如下:
public class TestRuntimeException {
public static void main(String[] args) {
String str="123";
int temp=Integer.parseInt(str);
System.out.println(temp*temp);
}
}
我們來看看parseInt方法的源代碼如下:
public static int parseInt(String s) throws NumberFormatException {
return parseInt(s,10);
}
我們發現這個方法中拋出了NumberFormatException異常,但是在上面的代碼中我們沒有找到try...catch來處理,這是為什麼呢。按照我們異常處理的知識,如果一個方法通過throws拋出了異常,那麼可以在拋出異常的方法中不適用try...catch,但是在調用這個方法的地方必須有try...catch來處理。可以發現NumberFormatException是RuntimeException的子類,那麼這就需要我們清楚Exception和RuntimeException的概念:
Exception:在程序中必須使用try...catch進行處理。
RuntimeException:可以不使用try...catch進行處理,但是如果有異常產生,則異常將由JVM進行處理。
對於RuntimeException的子類最好也使用異常處理機制。雖然RuntimeException的異常可以不使用try...catch進行處理,但是如果一旦發生異常,則肯定會導致程序中斷執行,所以,為了保證程序再出錯後依然可以執行,在開發代碼時最好使用try...catch的異常處理機制進行處理。
❼ java中錯誤(error)和異常(exception)有什麼主要區別
1.如圖Exception 和 Error都繼承自Throwable類,由jdk api文檔中對該類的描述可以知道它是異常處理機制的基本組成類型。可以由虛擬機拋出或者編碼者自行拋出(throw)
jdk8中文發翻譯Throwable類的描述:Throwable類是Java語言中所有錯誤和異常的Throwable類。 只有作為此類(或其一個子類)的實例的對象由Java虛擬機拋出,或者可以由Java throw語句拋出。 類似地,只有這個類或其子類可以是catch子句中的參數類型。
2.Exception 和 Error 體現了 Java 平台設計者對不同異常情況的分類。Exception 是程序正常運行中,可以預料的意外情況,可能並且應該被捕獲,進行相應處理。
3.Error 是指在正常情況下,不大可能出現的情況,絕大部分的 Error 都會導致程序(比如 JVM 自身)處於非正常的、不可恢復狀態。既然是非正常情況,所以不便於也不需要捕獲,常見的比如 OutOfMemoryError 之類,都是 Error 的子類。
4.Exception 又分為可檢查(checked)異常和不檢查(unchecked)異常,可檢查異常在源代碼里必須顯式地進行捕獲處理,這是編譯期檢查的一部分。前面我介紹的不可查的 Error,是 Throwable 不是 Exception。
如何處理這些異常?
在現實編程中我們一般使用 try-with-resources 和 multiple catch來進行一些異常處理(便利的特性),在編譯時期,會自動生成相應的處理邏輯,比如,自動按照約定俗成 close 那些擴展了 AutoCloseable 或者 Closeable 的對象。
try-with-resources 是一種處理Closeable實現類關閉資源的一種寫法,簡單寫了一個例子可以發現其實這就是一中語法,這種語法可以自動編譯幫忙編譯最後關閉流的操作:
public static void main(String[] args) {
try (BufferedReader br = new BufferedReader(new FileReader("a"));
BufferedWriter writer = new BufferedWriter(new FileWriter("a"))) {
// Try-with-resources
} catch (IOException e) {// Multiple catch
// Handle it
}
}
編譯後class
public static void main(String[] args) { try {
BufferedReader br = new BufferedReader(new FileReader("a"));
Throwable var2 = null; try {
BufferedWriter writer = new BufferedWriter(new FileWriter("a"));
Object var4 = null; if (writer != null) { if (var4 != null) { try {
writer.close();
} catch (Throwable var15) {
((Throwable)var4).addSuppressed(var15);
}
} else {
writer.close();
}
}
} catch (Throwable var16) {
var2 = var16; throw var16;
} finally { if (br != null) { if (var2 != null) { try {
br.close();
} catch (Throwable var14) {
var2.addSuppressed(var14);
}
} else {
br.close();
}
}
}
} catch (IOException var18) {
;
}
}
異常處理的兩個基本原則
盡量不要捕獲類似 Exception 這樣的通用異常,而是應該捕獲特定異常
這是因為在日常的開發和合作中,我們讀代碼的機會往往超過寫代碼,軟體工程是門協作的藝術,所以我們有義務讓自己的代碼能夠直觀地體現出盡量多的信息,而泛泛的 Exception 之類,恰恰隱藏了我們的目的。另外,我們也要保證程序不會捕獲到我們不希望捕獲的異常。比如,你可能更希望 RuntimeException 被擴散出來,而不是被捕獲。
不要生吞(swallow)異常。這是異常處理中要特別注意的事情,因為很可能會導致非常難以診斷的詭異情況。
如果我們不把異常拋出來,或者也沒有輸出到日誌(Logger)之類,程序可能在後續代碼以不可控的方式結束。沒人能夠輕易判斷究竟是哪裡拋出了異常,以及是什麼原因產生了異常。
在寫程序時可以通過Objects類(jdk提供),或者斷言等提前判斷問題,如空指針異常的一些值的處理Objects. requireNonNull(filename);而不是使用之後有問題再系統拋出異常,這可能就會不直觀的找到問題所在。即:Throw early, catch late 原則
希望對您有所幫助!~
❽ Java編程中 常見的異常有哪幾種
相信作為程序員的我們在對程序進行編譯過程中經常會遇到錯誤,或者在運行過程中出現錯誤,在這里主要跟大家談談經常遇到的一些異常與錯誤,以及解決辦法。
異常是指程序在編譯或運行過程出現的錯誤。
在java.lang包中Throwable包含了所有的異常。
Error (錯誤) 和Exception(異常)
(1)Error(錯誤)
一旦發生無法修復,但可以避免發生。
常見錯誤類:
IOError:I/O錯誤,當發生嚴重的I/O錯誤時,拋出此錯誤。
VirtualMachineError:虛擬機錯誤,當 Java 虛擬機崩潰或用盡了它繼續操作所需的資源時,拋出該錯誤。
StackOverflowError:棧內存滿了,當應用程序遞歸太深而發生堆棧溢出時,拋出該錯誤。
OutofMemoryError:堆內存滿了,因為內存溢出或沒有可用的內存提供給垃圾回收器時,Java 虛擬機無法分配一個對象,這時拋出該異常。
以上是一些常見的錯誤,在Error類中還有一些別的錯誤(參照文件Java.lang.Throwable.Error).
(2)Exception(異常)
一旦發生,可以捕獲並處理,不會導致程序終止,有時可以避免有時無法避免。
異常的分類:
1.編譯時異常(需要強制處理) 2.運行時異常(不需要強制處理)
常見的異常有:
IOException:輸入輸出流異常
FileNotFoundException:文件找不到的異常
ClassNotFoundException:類找不到的異常
DataFormatException:數據格式化異常
NoSuchFieldException:沒有匹配的屬性異常
NoSuchMethodException:沒有匹配的方法異常
SQLException:資料庫操作異常
TimeoutException:執行超時異常
常見的運行時異常:
RuntimeException:運行時異常
NullPointerException:空指針異常
:數組越界異
ClassCastException:類型轉換異常
IllegalArgumentException:非法的參數異常
InputMismatchException:輸入不匹配
以上是常見的一些異常,另外還有別的異常,參見文件:Java.lang.Throwable.Exception
既然我們常常會遇到一些異常,那我們如何來處理這些異常就是一個急需解決的事情。
(1) 如何處理編譯時異常?
方法一:將需要處理的代碼塊放在一個try...catch...中
try{
//需要處理異常的代碼
}catch(XXXException ef){
ef.printStackTrace();
}
我們方法一就是要將我們不確定的代碼放入try......catch中,先進行try一下,如果沒有異常,則不會觸發catch,沒有輸出,一旦出現異常,那麼catch就會工作,在catch中捕獲異常信息,根據異常信息進行補救措施。
如以下代碼:
從結果可以看出,我們在輸入數據的時候出現錯誤,這樣通過自定義異常能夠讓我們更直接快速的找到運行或編譯時的異常。
在上述中我們分別提到了三種throw,分別是Throwable,Throws以及throw,那麼到底三者有什麼區別?
Throwable:是指在在Java.lang包中的一個類,其包含了所有的異常和錯誤,其中類Error和Exception 是它
的子類。
Thows:是指在解決編譯時異常,將方法中異常拋給上一級,在方法後面要加Throw Exception來進行拋。
throw:是指在自定義異常時,如果方法出現異常,那麼將作為引用方法的對象拋出。即拋出異常。
希望對您有所幫助!~
❾ Java的Exception構造方法
Exception()
構造詳細消息為 null 的新異常。
Exception(String message)
構造帶指定詳細消息的新異常。
Exception(String message, Throwable cause)
構造帶指定詳細消息和原因的新異常。
Exception(Throwable cause)
根據指定的原因和 (cause==null ? null : cause.toString()) 的詳細消息構造新異常(它通常包含 cause 的類和詳細消息)。
❿ java中error與exception的區別是什麼
一、含義不同:
Error類一般是與虛擬機相關的問題,如系統崩潰,虛擬機錯誤,內存空間不足,方法調用棧溢等。對於這類錯誤的導致的應用程序中斷,僅靠程序本身無法恢復和和預防,遇到這樣的錯誤,建議讓程序終止。
Exception類表示程序可以處理的異常,可以捕獲且可能恢復。遇到這類異常,應該盡可能處理異常,使程序恢復運行,而不應該隨意終止異常。
二、用途不同:
Exception和Error體現了Java平台設計者對不同異常情況的分類。Exception是程序正常運行中,可以預料的意外情況,可能並且應該被捕獲,進行相應處理。
Error是指在正常情況下,不大可能出現的情況,絕大部分的Error都會導致程序處於非正常的、不可恢復狀態。既然是非正常情況,所以不便於也不需要捕獲,常見的比如OutOfMemoryError之類,都是Error的子類。
好處
讓異常處理與業務邏輯的主線分離,我們可以對可以遇見的異常作分支處理,其實將業務邏輯與異常處理分離也是Exception設計的主旨,其次Java Exception 不需要像C語言那樣在程序的多個地方去檢測同一個錯誤,並就地作異常的處理,相比老式的錯誤處理,現行的錯誤處理的結構則來的更加清晰。
以上內容參考:網路-Exception