異常處理經驗談

作者: gaoxiang  來源: 博客園  發布時間: 2008-09-09 16:17  閱讀: 2321 次  推薦: 0   原文鏈接   [收藏]  

  1、異常處理相對于返回錯誤代碼的一個最大優點在于,異常可以被自動傳遞,這樣,在編程時異常更加難以被忽視。

  2、通常,只在最上層(一般是UI層)捕捉異常。如果要在其它層捕捉異常,除非是下列情況之一:
   (1)能夠處理該異常,或者
   (2)能夠忽略該異常,或者
   (3)需要轉換該異常為其它特定異常后拋出新異常

  3、UI層捕獲異常后,可以
   (1)將無關緊要的異常忽略。
   (2)將異常轉換為錯誤信息展現給用戶。
   (3)如果是重大異常,可以考慮終止應用程序。

  4、最上層(一般是UI層)不得拋出新的異常;最上層需要捕捉所有異常,否則異常會直接導致程序終止,這將是非常不好的用戶體驗。

  5、可以在非最上層拋出自定義異常。如果是自定義異常,請保證其是可序列化的,并且保證其實現了Exception的三個構造函數。

  6、異常的拋出與截獲需要很多的cpu時間,請謹慎的使用異常。

  7、在可能拋出異常的地方,如果需要,請確保使用finally進行資源清理,而無論此處是否捕捉了異常。

  8、在一個catch塊中的代碼都應該至少部分地處理了所捕捉的異常。否則,就不要使用catch塊。

  9、從構造函數中拋出異常。因為構造函數沒有返回值,所以沒有簡單的方法來想構造函數的調用者發出構造失敗的信號,這時便可以通過拋出異常來做到。比如構造參數與指定條件不符時,就拋出一個異常。 

  10、在以上前提的保證下,可以在非最上層使用AOP截獲(intercept)異常而進行日志記錄,這樣通過日志記錄,我們可以了解系統的 運行狀態。記不起在哪里看到過這樣一句話:在軟件實現中,異常和日志都是重要的質量保證手段,異常和日志總是同時出現的。


  可以說,異常是日志記錄的重要/主要組成部分。

0
0
 
 
 

文章列表

arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()