Java程式設計中關於異常處理的10個最佳實踐
在實踐中,異常處理不單單是知道語法這麼簡單。編寫健壯的程式碼是更像是一門藝術,在本文中,將討論Java異常處理最佳實踐。這些Java最佳實踐遵循標準的JDK庫,和幾個處理錯誤和異常的開原始碼。這還是一個提供給java程式設計師編寫健壯程式碼的便利手冊。Java 程式設計中異常處理的最佳實踐
這裡是我收集的10個Java程式設計中進行異常處理的10最佳實踐。在Java程式設計中對於檢查異常有褒有貶,強制處理異常是一門語言的功能。在本文中,我們將盡量減少使用檢查型異常,同時學會在Java程式設計中使用檢查型VS非檢查型異常。
1)為可恢復的錯誤使用檢查型異常,為程式設計錯誤使用非檢查型錯誤。
選擇檢查型還是非檢查型異常,對於Java程式設計人員來說,總是讓人感到困惑。檢查型異常保證你對錯誤條件提供異常處理程式碼,這是一種從語言到強制你編寫健壯的程式碼的一種方式,但同時會引入大量雜亂的程式碼並導致其不可讀。當然,如果你有替代品和恢復策略的話,捕捉異常並做些什麼看起來似乎也在理。在Java 程式設計中選擇檢查型異常還是執行時異常,更多資訊參考checked vs unchecked exceptions。
2)在finally程式塊中關閉或者釋放資源
這在Java程式設計中,是一個廣為人知的最佳實踐,在處理網路和IO類的時候,相當於一個標準。在finally塊中關閉資源, 在正常和異常執行的情況下,保證之前和稀缺資源的合理釋放,這由y finally塊保證。從Java7開始,該語言有了一項更有趣的功能:資源管理自動化或者ARM塊能實現這一功能。儘管如此,我們仍然要記住在finally塊中關閉資源,這是對於釋放像FileDescriptors這類,應用在socket和檔案程式設計的情況下的有限資源很重要的。
3)在堆疊跟蹤中包含引起異常的原因
很多時候,當一個由另一個異常導致的異常被丟擲的時候,Java庫和開放原始碼會將一種異常包裝成另一種異常。日誌記錄和列印根異常就變得非常重要。 Java異常類提供了 getCause()方法來檢索導致異常的原因,這些(原因)可以對異常的根層次的原因提供更多的資訊。該Java實踐對在進行除錯或排除故障大有幫助。時刻記住,如果你將一個異常包裝成另一種異常時,構造一個新異常要傳遞源異常。
4)始終提供關於異常的有意義的完整的資訊
異常資訊是最重要的地方,因為這是程式設計師首先看到的第一個地方,這裡你能找到問題產生的根本原因。這裡始終提供精確的真實的資訊。例如,對比IllegalArgumentException 異常的兩條異常資訊:
訊息 1: “Incorrect argument for method”
訊息 2: “Illegal value for ${argument}: ${value}
第一條訊息僅說明了引數是非法的或者不正確,但第二條訊息包括了引數名和非法值,而這對於找到錯誤的原因是很重要的。在用Java程式設計中編寫異常處理程式碼的時候,始終遵循該Java最佳實踐。
5)避免過度使用檢查型異常
檢查型異常在強制執行方面有一定的優勢,但同時它也破壞了程式碼,通過掩蓋業務邏輯使程式碼可讀性降低。只要你不過度使用檢查型異常,你可以最大限度的減少這類情況,這樣做的結果是你會得到更清潔的程式碼。你同樣可以使用Java7的新功能,像one catch block for multiple exceptions 和 automatic resource management以移除重複項。
6)將檢查型異常轉為執行時異常
這是在像Spring之類的多數框架中用來限制使用檢查型異常的技術之一,大部分出自於JDBC的檢查型異常,都被包裝進 DataAccessException中,而(DataAccessException)異常是一種非檢查型異常。這是Java最佳實踐帶來的好處,特定的異常限制到特定的模組,像 SQLException 放到DAO層,將意思明確的執行時異常拋到客戶層。
7)記住對效能而言,異常代價高昂
需要記住的一件事是異常代價高昂,同時讓你的程式碼執行緩慢。假如你有方法從ResultSet(結果集)中進行讀取,這時常會丟擲SQLException 異常而不會移到下一元素,這將會比不丟擲異常的正常程式碼執行的慢的多。因此最大限度的減少不必要的異常捕捉和移動,那裡沒有什麼固定的原因。不要僅僅是丟擲和捕捉異常,如果你能使用boolean變數去表示執行結果,可能會得到更整潔,更高效能的解決方案。修正錯誤的根源,避免不必須要的異常捕捉。
8)避免catch塊為空
沒有什麼比空的catch塊更糟糕的了,因為它不僅隱藏了錯誤和異常,同時可能導致你的物件處於不可使用或者髒的狀態。空的catch塊只能變得無意義,如果你非常肯定異常不會繼續以任何方式影響物件狀態,但在程式執行期間,用日誌記錄錯誤依然是最好的(方法)。對於在Java程式設計中編寫異常處理程式碼,這不僅僅是一個Java最佳實踐,而是一個最通用的實踐。
9)使用標準異常
我們的第九條最佳實踐建議使用標準和內建的Java異常。使用標準異常而不是每次建立我們自己的異常,對於維護性和一致性,不管是現在還是以後,都是最好的選擇。重用標準異常使程式碼更具可讀性,因為大部分Java開發人員對標準的像源自於JDK的RuntimeException 異常,IllegalStateException 異常,IllegalArgumentException 異常或者NullPointerException異常,(開發者)他們能一眼就知道每種異常的目的,而不是在程式碼裡查詢或者在文件裡查詢使用者定義的異常的目的。
10)記錄任何方法丟擲的異常
Java提供了throw和throws關鍵字來丟擲異常,在javadoc中用@throw記錄任何方法可能會丟擲的異常。如果你編寫API或者公共介面,這就變得非常重要。任何方法丟擲的異常都有相應的文件記錄,這樣你就能下意識的提醒任何使用(該方法)的人。 這些就是所有在Java程式設計中在處理異常的時候需要遵循的最佳實踐。讓我們知道了什麼是在Java程式設計中編寫異常處理程式碼時需要遵循的實踐。
相關文章
- Java 程式設計中關於異常處理的 10 個最佳實踐Java程式設計
- 處理Java異常的10個最佳實踐Java
- Java中的異常處理最佳實踐Java
- 處理Java異常的9個最佳實踐Java
- Java異常處理的9個最佳實踐Java
- 20個異常處理的最佳實踐
- .NET中異常處理的最佳實踐
- 異常處理最佳實踐
- .NET中異常處理的最佳實踐(譯)
- Java中處理異常的9個最佳實踐,你必須要知道!Java
- Java異常處理最佳實踐及陷阱防範Java
- Android 異常處理最佳實踐Android
- [翻譯]-異常處理最佳實踐
- Java中異常處理和設計Java
- 關於java程式異常處理(講義)(轉)Java
- Java 理論與實踐: 關於異常的爭論Java
- Java異常處理設計(一)Java
- Java異常處理設計(二)Java
- Java異常處理設計(三)Java
- Java異常處理和設計Java
- Spring Boot統一異常處理最佳實踐Spring Boot
- java優雅的處理程式中的異常Java
- java程式設計學習知識點——java的異常處理Java程式設計
- Java程式設計師的八個最佳實踐Java程式設計師
- windows核心程式設計---未處理異常,向量化異常處理與C++異常Windows程式設計C++
- 好程式設計師Java培訓分享Java處理異常的幾個小知識程式設計師Java
- Java 中的異常處理機制Java
- JAVA 異常處理Java
- JAVA異常處理Java
- Java 異常處理Java
- 設計一個全域性異常處理器
- 關於複雜任務與異常處理的設計模式探討!設計模式
- Spring Boot 中關於自定義異常處理的套路!Spring Boot
- 關於專案中遇到的NullPointerException異常時處理手段NullException
- Java程式異常處理的特殊情況Java
- Python 程式設計高效技巧:最佳化、異常處理與效能提升Python程式設計
- Java程式設計細節之十個最佳實踐Java程式設計
- 關於resmgr:cpu quantum異常等待處理