C#中單例模式的實現(xiàn)代碼

本篇內容主要講解“C#中單例模式的實現(xiàn)代碼”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“C#中單例模式的實現(xiàn)代碼”吧!

專注于為中小企業(yè)提供網(wǎng)站設計、網(wǎng)站建設服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)永定免費做網(wǎng)站提供優(yōu)質的服務。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了近1000家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設實現(xiàn)規(guī)模擴充和轉變。

餓漢式實現(xiàn)很簡單,在靜態(tài)構造函數(shù)中立即進行實例化:

public class Singleton
{
   private static readonly Singleton _instance;
   static Singleton()
   {
       _instance = new Singleton();
   }

   public static Singleton Instance
   {
       get
       {
           return _instance;
       }
   }
}

注意,為了確保單例性,需要使用 readonly 關鍵字聲明實例不能被修改。

以上寫法可簡寫為:

public class Singleton
{
   private static readonly Singleton _instance = new Singleton();
   public static Singleton Instance
   {
       get
       {
           return _instance;
       }
   }
}

這里的 new Singleton() 等同于在靜態(tài)構造函數(shù)中實例化。在 C# 7 中還可以進一步簡寫如下:

public class Singleton
{
   public static Singleton Instance { get; } = new Singleton();
}

一句代碼就搞定了,此寫法,實例化也是在默認的靜態(tài)構造函數(shù)中進行的。如果是餓漢式需求,這種實現(xiàn)是最簡單的。有人會問這會不會有線程安全問題,如果多個線程同時調用 Singleton.Instance 會不會實例化了多個實例。不會,因為 CLR 確保了所有靜態(tài)構造函數(shù)都是線程安全的。

注意,不能這么寫:

public class Singleton
{
   public static Singleton Instance => new Singleton();
}

// 等同于:
public class Singleton
{
   public static Singleton Instance
   {
       get { return new Singleton(); }
   }
}

這樣會導致每次調用都會創(chuàng)建一個新實例。

懶漢式

懶漢式單例實現(xiàn)需要考慮線程安全問題,先來看一段經(jīng)典的線程安全的單列模式實現(xiàn)代碼:

public sealed class Singleton
{
   private static volatile Singleton _instance;
   private static readonly object _lockObject = new Object();

   public static Singleton Instance
   {
       get
       {
           if (_instance == null)
           {
               lock (_lockObject)
               {
                   if (_instance == null)
                   {
                       _instance = new Singleton();
                   }
               }
           }
           return _instance;
       }
   }
}

網(wǎng)上搜索 C# 單例模式,大部分都是這種使用 lock 來確保線程安全的寫法,這是經(jīng)典標準的單例模式的寫法,沒問題,很放心。在 lock 里外都做一次 instance 空判斷,雙保險,足以保證線程安全和單例性。但這種寫法似乎太麻煩了,而且容易寫錯。早在 C# 3.5 的時候,就有了更好的寫法,使用 Lazy<T>

示例代碼:

public class LazySingleton
{
   private static readonly Lazy<LazySingleton> _instance =
       new Lazy<LazySingleton>(() => new LazySingleton());

   public static LazySingleton Instance
   {
       get { return _instance.Value; }
   }
}

調用示例:

public class Program
{
   public static void Main()
   {
       var instance = LazySingleton.Instance;
   }
}

使用 Lazy<T> 可以使對象的實例化延遲到第一次被調用的時候執(zhí)行,通過訪問它的 Value 屬性來創(chuàng)建并獲取實例,并且讀取一個 Lazy<T> 實例的 Value 屬性只會執(zhí)行一次實例化代碼,確保了線程安全。

到此,相信大家對“C#中單例模式的實現(xiàn)代碼”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續(xù)學習!

名稱欄目:C#中單例模式的實現(xiàn)代碼
瀏覽路徑:http://muchs.cn/article46/ishghg.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站導航、App設計、外貿網(wǎng)站建設、響應式網(wǎng)站品牌網(wǎng)站建設、Google

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名