本篇內(nèi)容主要講解“C#單例模式引起的自定義異常舉例分析”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“C#單例模式引起的自定義異常舉例分析”吧!
專注于為中小企業(yè)提供成都做網(wǎng)站、網(wǎng)站設(shè)計(jì)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)江海免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了上1000家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。
案例代碼
對(duì)于單例模式,C#有個(gè)簡潔的實(shí)現(xiàn),采用靜態(tài)的只讀字段實(shí)現(xiàn)。
但是如果在單例模式構(gòu)造函數(shù)中,發(fā)生了異常自定義異常,在客戶端能捕捉到嗎?
代碼下載: ConfigException為我們定義異常類,TriggerException為異常觸發(fā)類。先不要運(yùn)行,猜下會(huì)捕捉到什么異常?
現(xiàn)實(shí)
事實(shí)上我們的自定義異常沒有沒Catch到,這是現(xiàn)象很隱蔽,主要是他不影響影響我們程序正常運(yùn)行,只是我們費(fèi)力定義的自定義異常都沒有起到任何的作用。
通常我們?cè)趩卫J降腜ortal工作,如果發(fā)生了異常,而如下日志記錄的異常粒度對(duì)于運(yùn)維一般參考價(jià)值不大
{"“ConsoleApplication4.Singleton”的類型初始值設(shè)定項(xiàng)引發(fā)異常。"} [System.TypeInitializationException]: {"“ConsoleApplication4.Singleton”的類型初始值設(shè)定項(xiàng)引發(fā)異常。"} Data: {System.Collections.ListDictionaryInternal} HelpLink: null InnerException: {"ComplicatedCalculate 的異常"} Message: "“ConsoleApplication4.Singleton”的類型初始值設(shè)定項(xiàng)引發(fā)異常。" Source: "ConsoleApplication4" StackTrace: " 在 ConsoleApplication4.Program.Main(String[] args) 位置 E:\\MyStudy\\ArchitectureHOL\\ConsoleApplication4\\ConsoleApplication4\\Program.cs:行號(hào) 16" TargetSite: {Void Main(System.String[])} 解決辦法
還是回到經(jīng)典的單例模式的實(shí)現(xiàn)。代碼如下:
public class Singleton { public readonly static Singleton instance = null; private static object objectLock = new object(); public int Age { get;set; } public static Singleton Instance { get { if (instance == null) { lock (objectLock) { if (instance == null) instance = new Singleton(); } } return instance; } } private Singleton() { TriggerException t = new TriggerException(); t.ComplicatedCalculate(); } }
這樣就可以Catch到我們自定義的異常了。
原因和疑惑
為什么字采用readonly Static 方式實(shí)現(xiàn)單例不能捕捉到自定的異常?這個(gè)也是調(diào)用構(gòu)造函數(shù)Singleton進(jìn)而觸發(fā)異常的,這個(gè)我解釋不清楚,也是我寫此文的主要目的,希望有人討論指點(diǎn)下。但是我想以下兩點(diǎn)很重要 :
C#靜態(tài)只讀字段在作為動(dòng)態(tài)常量在運(yùn)行時(shí)賦值的時(shí)候出現(xiàn)異常,.Net FrameWork把他作為一個(gè)一般異常進(jìn)行處理,把我們的自定義異常作為他的InnerException
C#靜態(tài)屬性在MSIL語言就是已經(jīng)看作為一個(gè)方法了。所以其調(diào)用的方法異常會(huì)被Catch而返回上一級(jí)調(diào)用者。
到此,相信大家對(duì)“C#單例模式引起的自定義異常舉例分析”有了更深的了解,不妨來實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!