您好,登錄后才能下訂單哦!
本篇內容主要講解“C#單例模式引起的自定義異常舉例分析”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“C#單例模式引起的自定義異常舉例分析”吧!
案例代碼
對于單例模式,C#有個簡潔的實現,采用靜態的只讀字段實現。
但是如果在單例模式構造函數中,發生了異常自定義異常,在客戶端能捕捉到嗎?
代碼下載: ConfigException為我們定義異常類,TriggerException為異常觸發類。先不要運行,猜下會捕捉到什么異常?
現實
事實上我們的自定義異常沒有沒Catch到,這是現象很隱蔽,主要是他不影響影響我們程序正常運行,只是我們費力定義的自定義異常都沒有起到任何的作用。
通常我們在單例模式的Portal工作,如果發生了異常,而如下日志記錄的異常粒度對于運維一般參考價值不大
{"“ConsoleApplication4.Singleton”的類型初始值設定項引發異常。"} [System.TypeInitializationException]: {"“ConsoleApplication4.Singleton”的類型初始值設定項引發異常。"} Data: {System.Collections.ListDictionaryInternal} HelpLink: null InnerException: {"ComplicatedCalculate 的異常"} Message: "“ConsoleApplication4.Singleton”的類型初始值設定項引發異常。" Source: "ConsoleApplication4" StackTrace: " 在 ConsoleApplication4.Program.Main(String[] args) 位置 E:\\MyStudy\\ArchitectureHOL\\ConsoleApplication4\\ConsoleApplication4\\Program.cs:行號 16" TargetSite: {Void Main(System.String[])} 解決辦法
還是回到經典的單例模式的實現。代碼如下:
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 方式實現單例不能捕捉到自定的異常?這個也是調用構造函數Singleton進而觸發異常的,這個我解釋不清楚,也是我寫此文的主要目的,希望有人討論指點下。但是我想以下兩點很重要 :
C#靜態只讀字段在作為動態常量在運行時賦值的時候出現異常,.Net FrameWork把他作為一個一般異常進行處理,把我們的自定義異常作為他的InnerException
C#靜態屬性在MSIL語言就是已經看作為一個方法了。所以其調用的方法異常會被Catch而返回上一級調用者。
到此,相信大家對“C#單例模式引起的自定義異常舉例分析”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。