異常處理是Java 開發中的一個重要部分。它是關乎每一個應用的一個非功能性需求,是爲了處理任何錯誤情況,好比資源不可訪問,非法輸入,空輸入等等。Java提供了幾個異常處理特性,以try,catch 和 finally 關鍵字的形式內建於語言自身之中。Java 編程語言也容許你建立新的異常,並經過使用 throw 和 throws關鍵字拋出它們。事實上,在Java編程中,Java的異常處理不僅僅是知道語法這麼簡單,它必須遵循標準的JDK庫,和幾個處理錯誤和異常的開源代碼。這裏咱們將討論一些關於異常處理的Java 最佳實踐。java
選擇檢查型仍是非檢查型異常,對於Java編程人員來講,老是讓人感到困惑。檢查型異常保證你對錯誤條件提供異常處理代碼,這是一種從語言到強制你編寫健壯的代碼的一種方式,但同時會引入大量雜亂的代碼並致使其不可讀。固然,若是你有替代品和恢復策略的話,捕捉異常並作些什麼看起來彷佛也在理。在Java 編程中選擇檢查型異常仍是運行時異常。程序員
這在Java編程中,是一個廣爲人知的最佳實踐,在處理網絡和IO類的時候,至關於一個標準。在finally塊中關閉資源, 在正常和異常執行的狀況下,保證以前和稀缺資源的合理釋放,這由finally塊保證。從Java7開始,該語言有了一項更有趣的功能:資源管理自動化或者ARM塊能實現這一功能。儘管如此,咱們仍然要記住在finally塊中關閉資源,這是對於釋放像FileDescriptors這類,應用在socket和文件編程的狀況下的有限資源很重要的。編程
不少時候,當一個由另外一個異常致使的異常被拋出的時候,Java庫和開放源代碼會將一種異常包裝成另外一種異常。日誌記錄和打印根異常就變得很是重要。 Java異常類提供了 getCause()方法來檢索致使異常的緣由,這些(緣由)能夠對異常的根層次的緣由提供更多的信息。該Java實踐對在進行調試或排除故障大有幫助。時刻記住,若是你將一個異常包裝成另外一種異常時,構造一個新異常要傳遞源異常。網絡
異常信息是最重要的地方,由於這是程序員首先看到的第一個地方,這裏你能找到問題產生的根本緣由。這裏始終提供精確的真實的信息。框架
檢查型異常在強制執行方面有必定的優點,但同時它也破壞了代碼,經過掩蓋業務邏輯使代碼可讀性下降。只要你不過分使用檢查型異常,你能夠最大限度的減小這類狀況,這樣作的結果是你會獲得更清潔的代碼。你一樣可使用Java7的新功能,以移除重複項。socket
這是在像Spring之類的多數框架中用來限制使用檢查型異常的技術之一,大部分出自於JDBC的檢查型異常,都被包裝進 DataAccessException中,而(DataAccessException)異常是一種非檢查型異常。這是Java最佳實踐帶來的好處,特定的異常限制到特定的模塊,像 SQLException 放到DAO層,將意思明確的運行時異常拋到客戶層。編程語言
須要記住的一件事是異常代價高昂,同時讓你的代碼運行緩慢。假如你有方法從ResultSet(結果集)中進行讀取,這時常會拋出SQLException 異常而不會移到下一元素,這將會比不拋出異常的正常代碼執行的慢的多。所以最大限度的減小沒必要要的異常捕捉和移動,那裏沒有什麼固定的緣由。不要僅僅是拋出和捕捉異常,若是你能使用boolean變量去表示執行結果,可能會獲得更整潔,更高性能的解決方案。修正錯誤的根源,避免沒必要需要的異常捕捉。工具
沒有什麼比空的catch塊更糟糕的了,由於它不只隱藏了錯誤和異常,同時可能致使你的對象處於不可以使用或者髒的狀態。空的catch塊只能變得無心義,若是你很是確定異常不會繼續以任何方式影響對象狀態,但在程序執行期間,用日誌記錄錯誤依然是最好的(方法)。對於在Java編程中編寫異常處理代碼,這不只僅是一個Java最佳實踐,而是一個最通用的實踐。性能
咱們的第九條最佳實踐建議使用標準和內置的Java異常。使用標準異常而不是每次建立咱們本身的異常,對於維護性和一致性,不論是如今仍是之後,都是最好的選擇。重用標準異常使代碼更具可讀性,由於大部分Java開發人員對標準的像源自於JDK的RuntimeException 異常,IllegalStateException 異常,Illegal Argument Exception 異常或者NullPointerException異常,(開發者)他們能一眼就知道每種異常的目的,而不是在代碼裏查找或者在文檔裏查找用戶定義的異常的目的。開放源代碼
Java提供了throw和throws關鍵字來拋出異常,在javadoc中用@throw記錄任何方法可能會拋出的異常。若是你編寫API或者公共接口,這就變得很是重要。任何方法拋出的異常都有相應的文檔記錄,這樣你就能下意識的提醒任何使用(該方法)的人。
這些就是全部在Java編程中在處理異常的時候須要遵循的最佳實踐。讓咱們知道了什麼是在Java編程中編寫異常處理代碼時須要遵循的實踐。