異常,爲咱們處理非正常的業務流程提供了很好的解決方案,若是你有過dbase、c、pascal等過程式語言開發的經歷,你必定會深入體會到,異常機制給你的代碼可讀行、可維護性帶來的好處,同時,程序的健壯性也獲得了加強。 java
在 java項目中,異常設計要注意下面的幾點。
1、自定義異常父類的選擇
A、自定義異常的父類,能夠選擇爲RuntimeException或Exception。RuntimeException是運行時異常,你能夠選擇它來作爲你的異常父類,由於這種異常不受到編譯器檢查,所以,給予了程序員很大的靈活性,程序員能夠處理這種異常,也能夠不處理(實際上並非不處理,而是不當即處理,等到一個合適的地方再進行處理)。選擇RuntimeException做爲父類,是不少框架常採用的,若是你是作底層框架的,能夠選擇 RuntimeException。
B、業務層異常,通常選擇Exception做爲父類,由於業務層異常比較重要,通常都是要由調用者進行處理或者是要告知調用者會發生這種異常。若是你的代碼是提供給第三方廠商用的,業務層封閉統一的異常就顯得很是的有必要。這類異常會強制要求程序員進行處理(異常轉譯或繼續聲明拋出),程序完整性、健壯性獲得了增強。
2、業務層自定義異常結構的設計
A、業務層自定義異常能夠考慮按子系統來劃分,也就是說,每個子系統(模塊)都有本身的異常定義,每一個子系統本身維護本身的,統一貫調用者拋出。
B、根據業務類型,從邏輯上劃分異常類型,好比:權限相關的,安全相關的,數據庫相關的等等。
總的來講,這兩種自定義異常也能夠混合使用,由於有的時候,子系統(業務模塊)自己就是從邏輯上進行劃分的。
3、異常結構定義
異常類的父類選定後,再定義本身的異常結構。通常的異常類中,要定義這麼一些東西。
A、描述字符串,說明異常的原由,或說明等。
B、異常碼。定義一個int或String類型的異常碼,異常碼在整個系統中統必定義,根據異常繼承結構,異常碼也能夠定義得有層次結構。異常碼在大的系統中比較常見,Oracle ,Sqlserver等數據庫產品中,或華爲、中興的一些驅動api中。
C、定義一個Throwable的成員變量,用以封裝異常結構鏈。
D、定義無參數、有參數(String,Throwable)的構造方法。
4、在WEB三層模型中,異常的處理
在經典的三層架構模型中,一般都是這樣來進行異常處理的:
A、持久層通常拋出的是RuntiomeException類型的異常,通常不處理,直接向上拋出。
B、業務層通常要封裝自定義異常,統一貫外拋出(這裏要注意,若是用spring在業務層管理異常,必定要配置好異常回滾類型,由於spring默認只回滾RuntiomeException類型的)。我也見過一些想省事的人,業務層也不定義任何異常,也不進行try catch,若是業務層出現異常將在表現層進行處理及頁面跳轉。
C、表現層必需要處理業務層的異常,以正確向客戶報告系統出現的問題,這裏面是最後一道異常處理的地方。我也見過有懶人在業務層都不處理,直接在web.xml中配置errorPage的,但不建議這麼作。
用好異常,對於項目的可維護性、健壯性都有極大的好處,固然,異常也不是萬能的,在有些項目中並不適用,好比:純算法項目,對性能要求極高的項目等,由於異常棧會對系統性能有必定開銷,在這些項目中,最後還在老老實實用方法的返回值去標識方法執行的結果,用if else去處理業務邏輯中的非正常狀況吧。