總結(jié)十條.NET異常處理建議
.NET中從始至終要緊記異常處理的策略:拋出具體的一個異常,而不是只拋出Exception類型的異常,這樣能方便我們捕獲對應(yīng)類型的異常。我們在編寫代碼時要注意考慮到應(yīng)用程序最差的情況;顯示有好的信息,并提供適當(dāng)?shù)墓芾韱T聯(lián)系信息。
1、不要拋出“new Exception()”
請別這樣做。Exception是一個非常抽象的異常類,捕獲這類異常通常會產(chǎn)生很多負(fù)面影響。通常情況下應(yīng)該定義我們自己的異常類,并且需要區(qū)分系統(tǒng)拋出的異常和我們自己拋出的異常。
2、不要將重要的異常信息存儲在Message屬性中
異常都封裝在類中。當(dāng)你需要返回異常信息時,請將信息存儲在一些單獨(dú)的屬性中(而不要放在Message屬性中),否則人們很難從Message屬性中解析出他們需要的信息。比如當(dāng)你僅僅需要糾正一下拼寫錯誤,如果你將錯誤信息和其它提示內(nèi)容一起以String的形式寫在了Message屬性中,那么別人該怎樣簡單地獲取他們要的錯誤信息呢?你很難想象到他們要做多少努力。
3、每個線程要包含一個try/catch塊
一般異常處理都放在了程序中一個比較集中的地方。每個線程都需要有一個try/catch塊,否則你會漏掉某些異常從而出現(xiàn)難以理解的問題。當(dāng)一個程序開啟了多個線程去處理后臺任務(wù)時,通常你會創(chuàng)建一個類型來存儲各個線程執(zhí)行的結(jié)果。這時候請不要忘記了為類型增加一個字段來存儲每個線程可能發(fā)生的異常,否則的話,主線程不會知道其他線程的異常情況。在一些“即發(fā)即忘”的場合,你可能需要將主線程中的異常處理邏輯復(fù)制一份到你的子線程中去。
4、捕獲異常后要記錄下來
不管你的程序是使用何種方式記錄日志——log4net、EIF、Event Log、TraceListeners或者文本文件等,這些都不重要。重要的是:當(dāng)你遇到異常后,應(yīng)該在某個地方將它記錄在日志中。但是請僅僅記錄一次,否則的話,你最后會得到一個非常大的日志文件,包含了許多重復(fù)信息。
5、不要只記錄Exception.Message的值,還需要記錄Exception.ToString()
當(dāng)我們談到記錄日志時,不要忘了我們應(yīng)該記錄Exception.ToString()的值,而不是Exception.Message。因?yàn)镋xception.ToString()包含了“堆棧跟蹤”信息,內(nèi)部異常信息以及Message。通常這些信息非常重要,而如果你只記錄Exception.Message的話,你只可能看到類似“對象引用未指向堆中實(shí)例”這樣的提示。
6、要捕獲具體的異常
如果你要捕獲異常,請盡可能的捕獲具體異常(而非Exception)。好的代碼只能捕獲它知道該怎么處理的異常
7、不要忘記使用using
僅僅調(diào)用對象的Dispose()方法是不夠的。即使異常發(fā)生時,using關(guān)鍵字也能夠防止資源泄漏
8、不要使用特殊返回值去表示方法中發(fā)生的異常
1)、直接拋出異常更快,因?yàn)槭褂锰厥獾姆祷刂当硎井惓r,我們每次調(diào)用完方法時,都需要去檢查返回結(jié)果,并且這至少要多占用一個寄存器。降低代碼運(yùn)行速度。
2)、特殊返回值能,并且很可能被忽略
3)、特殊返回值不能包含堆棧跟蹤信息,不能返回異常的詳細(xì)信息
4)、很多時候,不存在一個特殊值去表示方法中發(fā)生的異常,比如,除數(shù)為零的情況
9、不要將“拋出異?!弊鳛楹瘮?shù)執(zhí)行結(jié)果的一種
這是一個非常糟糕的設(shè)計(jì)。代碼中包含太多的try/catch塊會使代碼難以理解,恰當(dāng)?shù)脑O(shè)計(jì)完全可以滿足一個方法返回各種不同的執(zhí)行結(jié)果,如果你確實(shí)需要通過拋出異常來表示方法的執(zhí)行結(jié)果,那只能說明你這個方法做了太多事情,必須進(jìn)行拆分
10、可以使用“拋出異常”的方式去著重說明不能被忽略的錯誤
例如我為我的一個產(chǎn)品開發(fā)了一個用來登錄的API(Login),如果用戶登錄失敗,或者用戶并沒有調(diào)用Login方法,那么他們調(diào)用其他方法時都會失敗。我在設(shè)計(jì)Login方法的時候這樣做的:如果用戶登錄失敗,它會拋出一個異常,而并不是簡單的返回false。正因?yàn)檫@樣,調(diào)用者(用戶)才不會忽略(他還沒登錄)這個事實(shí)。
ps: .Net異常處理的四要素
1.一個表示異常詳細(xì)信息的類。
2.一個像調(diào)用者引發(fā)異常類實(shí)例的成員。
3.調(diào)用者的一段調(diào)用異常成員的的模塊。
4.調(diào)用者的一段處理或捕獲將要發(fā)生異常的代碼塊。
相關(guān)文章
使用最小?WEB?API?實(shí)現(xiàn)文件上傳會遇到的坑
這篇文章主要介紹分享使用最小?WEB?API?實(shí)現(xiàn)文件上傳時會遇到的坑,在使用?.NET?6?的最小?WEB?API?來實(shí)現(xiàn)相同功能時,總是會意外地遇到了不少坑,下面我們就來看看這些坑都是怎么處理的吧,需要的朋友可以參考下2022-02-02asp.net listbox實(shí)現(xiàn)單選全選取消
這篇文章主要介紹了asp.net listbox單選全選取消的應(yīng)用,需要的朋友可以參考下2014-02-02asp.net動態(tài)獲取Excel表名的函數(shù)代碼
asp.net動態(tài)獲取Excel表名的函數(shù)代碼,需要的朋友可以參考下。2011-02-02ASP.NET URL偽靜態(tài)重寫實(shí)現(xiàn)方法
ASP.NET下為靜態(tài)的實(shí)現(xiàn)方法。2009-12-12使用DataAdapter填充多個表(利用DataRelation)的實(shí)例代碼
使用DataAdapter填充多個表(利用DataRelation)的實(shí)例代碼,需要的朋友可以參考一下2013-03-03Grid或者DataTable中數(shù)據(jù)導(dǎo)出為Excel原來這么簡單
以前一直認(rèn)為,將Grid 或者DataTable中的數(shù)據(jù)導(dǎo)出到Excel功能實(shí)現(xiàn)會非常復(fù)雜,可能會想用什么類庫什么的或者實(shí)在太難就用csv算了,沒想到真的很簡單,需要了解的朋友可以參考下2012-12-12ASP.NET 頁面間數(shù)據(jù)傳遞方法小結(jié)
Web 頁面是無狀態(tài)的, 服務(wù)器對每一次請求都認(rèn)為來自不同用戶,因此,變量的狀態(tài)在連續(xù)對同一頁面的多次請求之間或在頁面跳轉(zhuǎn)時不會被保留。2009-12-12asp.net利用存儲過程和div+css實(shí)現(xiàn)分頁(類似于博客園首頁分頁)
怎么用aspnetpager.dll這個插件對服務(wù)器控件進(jìn)行分頁,今天與我大家分享一下asp.net利用存儲過程和div+css實(shí)現(xiàn)分頁(類似于博客園首頁分頁)2012-01-01