国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

單例

2019-11-17 03:15:03
字體:
來源:轉載
供稿:網友
單例

在《Design Patterns:Elements of Resuable Object-Oriented Software》中的定義是:Ensurea class only has one instance,and PRovide a global point of access to。它的主要特點不是根據客戶程序調用生成一個新的實例,而是控制某個類型的實例數量-唯一一個。(《設計模式-基于C#的工程化實現及擴展》,王翔)。也就是說,單例模式就是保證在整個應用程序的生命周期中,在任何時刻,被指定的類只有一個實例,并為客戶程序提供一個獲取該實例的全局訪問點。

  一、經典模式:

public class Singleton{        private static Singleton instance;        private Singleton()        {                }        public static Singleton GetInstance()        {                if(instance==null)                {                        instance=new Singleton();                }                return instance;        }}

解析如下:

  1)首先,該Singleton的構造函數必須是私有的,以保證客戶程序不會通過new()操作產生一個實例,達到實現單例的目的;

  2)因為靜態變量的生命周期跟整個應用程序的生命周期是一樣的,所以可以定義一個私有的靜態全局變量instance來保存該類的唯一實例;

  3)必須提供一個全局函數訪問獲得該實例,并且在該函數提供控制實例數量的功能,即通過if語句判斷instance是否已被實例化,如果沒有則可以同new()創建一個實例;否則,直接向客戶返回一個實例。

  在這種經典模式下,沒有考慮線程并發獲取實例問題,即可能出現兩個線程同時獲取instance實例,且此時其為null時,就會出現兩個線程分別創建了instance,違反了單例規則。因此,需對上面代碼修改。

  二、多線程下的單例模式

  1、Lazy模式

public class Singleton{       private static Singleton instance;       private static object _lock=new object();       private Singleton()       {       }       public static Singleton GetInstance()       {               if(instance==null)               {                      lock(_lock)                      {                             if(instance==null)                             {                                     instance=new Singleton();                             }                      }               }               return instance;       }}

上述代碼使用了雙重鎖方式較好地解決了多線程下的單例模式實現。先看內層的if語句塊,使用這個語句塊時,先進行加鎖操作,保證只有一個線程可以訪問該語句塊,進而保證只創建了一個實例。再看外層的if語句塊,這使得每個線程欲獲取實例時不必每次都得加鎖,因為只有實例為空時(即需要創建一個實例),才需加鎖創建,若果已存在一個實例,就直接返回該實例,節省了性能開銷。

  2、餓漢模式

  這種模式的特點是自己主動實例。

public sealed class Singleton{        private static readonly Singleton instance=new Singleton();         private Singleton()        {        }        public static Singleton GetInstance()        {               return instance;        }}

上面使用的readonly關鍵可以跟static一起使用,用于指定該常量是類別級的,它的初始化交由靜態構造函數實現,并可以在運行時編譯。在這種模式下,無需自己解決線程安全性問題,CLR會給我們解決。由此可以看到這個類被加載時,會自動實例化這個類,而不用在第一次調用GetInstance()后才實例化出唯一的單例對象。

轉自:http://m.survivalescaperooms.com/xun126/archive/2011/03/09/1970807.html


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宁城县| 冷水江市| 安陆市| 宝应县| 兴业县| 昭平县| 通辽市| 榆社县| 甘孜县| 杨浦区| 怀仁县| 小金县| 汝南县| 应城市| 合肥市| 绍兴市| 丰镇市| 陇川县| 黄龙县| 河源市| 齐齐哈尔市| 同心县| 郧西县| 渭源县| 哈尔滨市| 普兰县| 武安市| 莱芜市| 桂林市| 治多县| 通渭县| 嘉义市| 冷水江市| 七台河市| 沙田区| 十堰市| 赫章县| 内丘县| 阿拉善右旗| 会泽县| 格尔木市|