重慶分公司,新征程啟航
為企業(yè)提供網站建設、域名注冊、服務器等服務
為企業(yè)提供網站建設、域名注冊、服務器等服務
throws捕獲并向外拋出異常\x0d\x0athrow拋出異常\x0d\x0atry catch是內部捕獲異常并做自定義處理\x0d\x0afinally是無論是否有異常都會被處理的語句,除非在finally前存在被執(zhí)行的System.exit(int i)時除外
創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網綜合服務,包含不限于成都網站制作、網站建設、外貿網站建設、天心網絡推廣、微信小程序開發(fā)、天心網絡營銷、天心企業(yè)策劃、天心品牌公關、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運營等,從售前售中售后,我們都將竭誠為您服務,您的肯定,是我們最大的嘉獎;創(chuàng)新互聯(lián)為所有大學生創(chuàng)業(yè)者提供天心建站搭建服務,24小時服務熱線:13518219792,官方網址:www.cdcxhl.com
Java語言提供兩種異常處理機制:捕獲異常和聲明拋棄異常;
1)捕獲異常:在Java程序運行過程中系統(tǒng)得到一個異常對象是,它將會沿著方法的調用棧逐層回溯,尋找處理這一異常的代碼。找到能夠處理這種類型異常的方法后,運行時系統(tǒng)把當前異常交給這個方法處理;如果找不到可以捕獲異常的方法,則運行時系統(tǒng)將終止,相應的Java程序也將退出。捕獲異常是通過try-catch-finally語句實現(xiàn)的。語法為:
try{
...
}catch(ExceptionName1 e){
...
}catch(ExceptionName2 e){
...
}
...
}finally{
...
}
2)聲明拋棄異常:當Java程序運行時系統(tǒng)得到一個異常對象時,如果一個方法并不知道如何處理所出現(xiàn)的異常,則可在方法聲明時,聲明拋棄異常。聲明拋棄異常是在一個方法聲明中的throws子句中指明的。如:
public int read() throws IOException{
...
}
其中throws IOException就是聲明拋棄異常,throws后可以跟多個異常類型。
Java中的異常處理機制已經比較成熟,我們的Java程序到處充滿了異常的可能,如果對這些異常不做預先的處理,那么將來程序崩潰就無從調試,很難找到異常所在的位置。
河北電腦培訓將探討一下Java中異常與錯誤的處理方法,一起來看看。
異常與錯誤:異常:在Java中程序的錯誤主要是語法錯誤和語義錯誤,一個程序在編譯和運行時出現(xiàn)的錯誤我們統(tǒng)一稱之為異常,它是VM(虛擬機)通知你的一種方式,通過這種方式,VM讓你知道,你(開發(fā)人員)已經犯了個錯誤,現(xiàn)在有一個機會來修改它。
Java中使用異常類來表示異常,不同的異常類代表了不同的異常。
但是在Java中所有的異常都有一個基類,叫做Exception。
錯誤:它指的是一個合理的應用程序不能截獲的嚴重的問題。
大多數(shù)都是反常的情況。
錯誤是VM的一個故障(雖然它可以是任何系統(tǒng)級的服務)。
所以,錯誤是很難處理的,一般的開發(fā)人員(當然不是你)是無法處理這些錯誤的,比如內存溢出。
和異常一樣,在Java中用錯誤類來表示錯誤,不同的錯誤類代表了不同的錯誤。
但是在Java中所有的錯誤都有一個基類,叫做Error。
綜上,我們可以知道異常和錯誤最本質的區(qū)別就是異常能被開發(fā)人員處理而錯誤時系統(tǒng)本來自帶的,一般無法處理也不需要我們程序員來處理。
1.一個異常是在一個程序執(zhí)行過程中出現(xiàn)的一個事件,它中斷了正常指令的運行2.錯誤,偏離了可接受的代碼行為的一個動作或實例異常的結構分類:1、運行時異常(未檢查異常)2、編譯時異常(已檢查異常)運行異常即是RuntimeException;其余的全部為編譯異常在Java中異常Exception和錯誤Error有個共同的父類Throwable。
ErrorExceptionruntimeException幾個子類1、java.lang.ArrayIndexOutOfBoundsException數(shù)組索引越界異常。
當對數(shù)組的索引值為負數(shù)或大于等于數(shù)組大小時拋出。
2、java.lang.ArithmeticException算術條件異常。
譬如:整數(shù)除零等。
3、java.lang.NullPointerException空指針異常。
當應用試圖在要求使用對象的地方使用了null時,拋出該異常。
譬如:調用null對象的實例方法、訪問null對象的屬性、計算null對象的長度、使用throw語句拋出null等等4、java.lang.ClassNotFoundException找不到類異常。
當應用試圖根據(jù)字符串形式的類名構造類,而在遍歷CLASSPAH之后找不到對應名稱的class文件時,拋出該異常。
比如一個異常,在當前類你不希望處理它,而想讓調用他的類處理,那么就throw這個異常
如果想在當前類處理,則try
catch這個異常
若是throw的話,則發(fā)現(xiàn)異常直接拋回給上層,執(zhí)行順序是:拋出異常、上層處理
若try
catch的話
try{
new
Exception();
}catch(Exception
ex){
這里處理異常
}
如果有finally塊的話
執(zhí)行順序為:
try、catch、finally
finally無論是否有異常都將執(zhí)行。
內存溢出不是異常,是Error,可以把Error當做不可以捕捉的Exception(ThreadDeath除外),Error是程序無法處理的錯誤,一般由JVM處理,比如殺死該線程,不要試圖捕捉Error。
一旦出現(xiàn)內存溢出錯誤,整個JVM就崩潰了,因此不存在捕獲的可能性。
異常處理是Java開發(fā)中的一個重要部分。
它是關乎每個應用的一個非功能性需求,是為了處理任何錯誤狀況,比如資源不可訪問,非法輸入,空輸入等等。
Java提供了幾個異常處理特性,以try,catch和finally關鍵字的形式內建于語言自身之中。
Java編程語言也允許你創(chuàng)建新的異常,并通過使用throw和throws關鍵字拋出它們。
事實上,在Java編程中,Java的異常處理不單單是知道語法這么簡單,它必須遵循標準的JDK庫,和幾個處理錯誤和異常的開源代碼。
這里北大青鳥將討論一些關于異常處理的Java最佳實踐。
1、為可恢復的錯誤使用檢查型異常,為編程錯誤使用非檢查型錯誤。
選擇檢查型還是非檢查型異常,對于Java編程人員來說,總是讓人感到困惑。
檢查型異常保證你對錯誤條件提供異常處理代碼,這是一種從語言到強制你編寫健壯的代碼的一種方式,但同時會引入大量雜亂的代碼并導致其不可讀。
當然,如果你有替代品和恢復策略的話,捕捉異常并做些什么看起來似乎也在理。
在Java編程中選擇檢查型異常還是運行時異常。
2、在finally程序塊中關閉或者釋放資源這在Java編程中,是一個廣為人知的最佳實踐,在處理網絡和IO類的時候,相當于一個標準。
在finally塊中關閉資源,在正常和異常執(zhí)行的情況下,保證之前和稀缺資源的合理釋放,這由finally塊保證。
從Java7開始,該語言有了一項更有趣的功能:資源管理自動化或者ARM塊能實現(xiàn)這一功能。
盡管如此,我們仍然要記住在finally塊中關閉資源,這是對于釋放像FileDescriptors這類,應用在socket和文件編程的情況下的有限資源很重要的。
3、在堆棧跟蹤中包含引起異常的原因很多時候,當一個由另一個異常導致的異常被拋出的時候,Java庫和開放源代碼會將一種異常包裝成另一種異常。
日志記錄和打印根異常就變得非常重要。
Java異常類提供了getCause方法來檢索導致異常的原因,這些(原因)可以對異常的根層次的原因提供更多的信息。
該Java實踐對在進行調試或排除故障大有幫助。
時刻記住,如果你將一個異常包裝成另一種異常時,構造一個新異常要傳遞源異常。
4、始終提供關于異常的有意義的完整的信息異常信息是最重要的地方,因為這是程序員首先看到的第一個地方,這里你能找到問題產生的根本原因。
這里始終提供精確的真實的信息。
5、避免過度使用檢查型異常檢查型異常在強制執(zhí)行方面有一定的優(yōu)勢,但同時它也破壞了代碼,通過掩蓋業(yè)務邏輯使代碼可讀性降低。
只要你不過度使用檢查型異常,你可以最大限度的減少這類情況,這樣做的結果是你會得到更清潔的代碼。
你同樣可以使用Java7的新功能,以移除重復項。
6、將檢查型異常轉為運行時異常這是在像Spring之類的多數(shù)框架中用來限制使用檢查型異常的技術之一,大部分出自于JDBC的檢查型異常,都被包裝進DataAccessException中,而(DataAccessException)異常是一種非檢查型異常。
這是Java最佳實踐帶來的好處,特定的異常限制到特定的模塊,像SQLException放到DAO層,將意思明確的運行時異常拋到客戶層。
7、記住對性能而言,異常代價高昂需要記住的一件事是異常代價高昂,同時讓你的代碼運行緩慢。
假如你有方法從ResultSet(結果集)中進行讀取,這時常會拋出SQLException異常而不會移到下一元素,這將會比不拋出異常的正常代碼執(zhí)行的慢的多。
因此最大限度的減少不必要的異常捕捉和移動,那里沒有什么固定的原因。
不要僅僅是拋出和捕捉異常,如果你能使用boolean變量去表示執(zhí)行結果,可能會得到更整潔,更高性能的解決方案。
修正錯誤的根源,避免不必須要的異常捕捉。