C#中使用擴(kuò)展方法對(duì)調(diào)用進(jìn)行驗(yàn)證
請(qǐng)先看下面的代碼
{ |
當(dāng)方法返回的結(jié)果為null時(shí),采用如下方式進(jìn)行調(diào)用,就會(huì)拋出NullReferenceException異常:
Customer customer =newCustomerDAL().FindCustomers(Role.Admin).First(); |
我們需要對(duì)返回結(jié)果進(jìn)行驗(yàn)證,如果返回為null,則可以拋出自定義異常,或者創(chuàng)建一個(gè)空對(duì)象,例如:
publicIEnumerable FindCustomers(stringroleName) |
如果系統(tǒng)有許多方法都需要對(duì)返回結(jié)果進(jìn)行驗(yàn)證,則這樣的驗(yàn)證邏輯就會(huì)充斥在各個(gè)方法體中,既不利于重用,也會(huì)對(duì)未來的修改造成極大的阻礙。當(dāng)然,我們可以引入Null Object模式來替代對(duì)null值的判斷邏輯,但這種方式仍然需要為多種類型定義不同的Null Object類型。
Craig Andera在其博客文章中提出使用擴(kuò)展方法對(duì)調(diào)用進(jìn)行驗(yàn)證。他寫道:NullReferenceException異常會(huì)拋出,但是我們希望有更具體的異常信息。因此,我們編寫了如下的擴(kuò)展方法:
publicstaticT OrThrow(thisT obj, Exception e){ |
OrThrow擴(kuò)展方法對(duì)于你所要調(diào)用的類型而言是通用的,并且它返回了該類型,所以你可以將其插入到表達(dá)式鏈中,而不會(huì)丟失智能感應(yīng)功能。并且因?yàn)轭愋屯茢喙δ?,?shí)際上并不需要指定具體的類型。
也就是說,OrThrow擴(kuò)展方法可以應(yīng)用到任何類型上,因此它可以在各種類型上重用非空驗(yàn)證甚至是調(diào)用驗(yàn)證。借鑒這一思想,我們還可以利用此方法默認(rèn)實(shí)現(xiàn)對(duì)象實(shí)例的創(chuàng)建,以避免拋出NullReferenceException異常,例如:
publicstaticT Instance(thisT obj) where T:new() |
由于Instance擴(kuò)展方法中的類型參數(shù)T需要?jiǎng)?chuàng)建實(shí)例,因此必須添加new()約束。所以該擴(kuò)展方法存在一定的局限,例如無法應(yīng)用在之前的IEnumerable類型上。但對(duì)于如下的方法卻非常有效:
publicclassListObject |
通過Instance擴(kuò)展方法,可以安全地調(diào)用List的相關(guān)屬性和方法,例如Count屬性:
Console.WriteLine(newListObject().Foo().Instance().Count); |
控制臺(tái)打印出來的結(jié)果為0。如果沒有Instance擴(kuò)展方法,則會(huì)拋出NullReferenceException異常。
作為C# 3.0增加的新特性,擴(kuò)展方法在大量項(xiàng)目中得到了廣泛地應(yīng)用,但絕不僅僅是提高可擴(kuò)展性這么簡(jiǎn)單。在進(jìn)行項(xiàng)目開發(fā)時(shí),若能適當(dāng)?shù)乜紤]使用擴(kuò)展方法,說不定會(huì)帶來出奇制勝的效果。
【編輯推薦】