天天看點

Java開發中異常處理的最佳實踐

Java開發中異常處理的最佳實踐

異常處理是java

開發中的一個重要部分。它是關乎每個應用的一個非功能性需求,是為了處理任何錯誤狀況,比如資源不可通路,非法輸入,空輸入等等。java提供了幾個異常處理特性,以try,catch

和 finally 關鍵字的形式内建于語言自身之中。java 程式設計語言也允許你建立新的異常,并通過使用 throw 和

throws關鍵字抛出它們。事實上,在java程式設計中,java的異常處理不單單是知道文法這麼簡單,它必須遵循标準的jdk庫,和幾個處理錯誤和異常的開源代碼。這裡我們将讨論一些關于異常處理的java

最佳實踐。

1)為可恢複的錯誤使用檢查型異常,為程式設計錯誤使用非檢查型錯誤。

選擇檢查型還是非檢查型異常,對于java程式設計人員來說,總是讓人感到困惑。檢查型異常保證你對錯誤條件提供異常處理代碼,這是一種從語言到強制你編寫健壯的代碼的一種方式,但同時會引入大量雜亂的代碼并導緻其不可讀。當然,如果你有替代品和恢複政策的話,捕捉異常并做些什麼看起來似乎也在理。在java

程式設計中選擇檢查型異常還是運作時異常。

2)在finally程式塊中關閉或者釋放資源

這在java程式設計中,是一個廣為人知的最佳實踐,在處理網絡和io類的時候,相當于一個标準。在finally塊中關閉資源,

在正常和異常執行的情況下,保證之前和稀缺資源的合理釋放,這由finally塊保證。從java7開始,該語言有了一項更有趣的功能:資源管理自動化或者arm塊能實作這一功能。盡管如此,我們仍然要記住在finally塊中關閉資源,這是對于釋放像filedescriptors這類,應用在socket和檔案程式設計的情況下的有限資源很重要的。

3)在堆棧跟蹤中包含引起異常的原因

很多時候,當一個由另一個異常導緻的異常被抛出的時候,java庫和開放源代碼會将一種異常包裝成另一種異常。日志記錄和列印根異常就變得非常重要。

java異常類提供了

getcause()方法來檢索導緻異常的原因,這些(原因)可以對異常的根層次的原因提供更多的資訊。該java實踐對在進行調試或排除故障大有幫助。時刻記住,如果你将一個異常包裝成另一種異常時,構造一個新異常要傳遞源異常。

4)始終提供關于異常的有意義的完整的資訊

異常資訊是最重要的地方,因為這是程式員首先看到的第一個地方,這裡你能找到問題産生的根本原因。這裡始終提供精确的真實的資訊。

5)避免過度使用檢查型異常

檢查型異常在強制執行方面有一定的優勢,但同時它也破壞了代碼,通過掩蓋業務邏輯使代碼可讀性降低。隻要你不過度使用檢查型異常,你可以最大限度的減少這類情況,這樣做的結果是你會得到更清潔的代碼。你同樣可以使用java7的新功能,以移除重複項。

6)将檢查型異常轉為運作時異常

這是在像spring之類的多數架構中用來限制使用檢查型異常的技術之一,大部分出自于jdbc的檢查型異常,都被包裝進

dataaccessexception中,而(dataaccessexception)異常是一種非檢查型異常。這是java最佳實踐帶來的好處,特定的異常限制到特定的子產品,像

sqlexception 放到dao層,将意思明确的運作時異常抛到客戶層。

7)記住對性能而言,異常代價高昂

需要記住的一件事是異常代價高昂,同時讓你的代碼運作緩慢。假如你有方法從resultset(結果集)中進行讀取,這時常會抛出sqlexception

異常而不會移到下一進制素,這将會比不抛出異常的正常代碼執行的慢的多。是以最大限度的減少不必要的異常捕捉和移動,那裡沒有什麼固定的原因。不要僅僅是抛出和捕捉異常,如果你能使用boolean變量去表示執行結果,可能會得到更整潔,更高性能的解決方案。修正錯誤的根源,避免不必須要的異常捕捉。

8)避免catch塊為空

沒有什麼比空的catch塊更糟糕的了,因為它不僅隐藏了錯誤和異常,同時可能導緻你的對象處于不可使用或者髒的狀态。空的catch塊隻能變得無意義,如果你非常肯定異常不會繼續以任何方式影響對象狀态,但在程式執行期間,用日志記錄錯誤依然是最好的(方法)。對于在java程式設計中編寫異常處理代碼,這不僅僅是一個java最佳實踐,而是一個最通用的實踐。

9)使用标準異常

我們的第九條最佳實踐建議使用标準和内置的java異常。使用标準異常而不是每次建立我們自己的異常,對于維護性和一緻性,不管是現在還是以後,都是最好的選擇。重用标準異常使代碼更具可讀性,因為大部分java開發人員對标準的像源自于jdk的runtimeexception

異常,illegalstateexception 異常,illegal argument exception

異常或者nullpointerexception異常,(開發者)他們能一眼就知道每種異常的目的,而不是在代碼裡查找或者在文檔裡查找使用者定義的異常的目的。

10)記錄任何方法抛出的異常

java提供了throw和throws關鍵字來抛出異常,在javadoc中用@throw記錄任何方法可能會抛出的異常。如果你編寫api或者公共接口,這就變得非常重要。任何方法抛出的異常都有相應的文檔記錄,這樣你就能下意識的提醒任何使用(該方法)的人。

這些就是所有在java程式設計中在處理異常的時候需要遵循的最佳實踐。讓我們知道了什麼是在java程式設計中編寫異常處理代碼時需要遵循的實踐。

作者:佚名

來源:51cto