vlambda博客
学习文章列表

【视觉知识】单例模式


引言

单例模式就是保证在整个应用程序的生命周期中,在任何时刻,被指定的类只有一个实例,并为客户程序提供一个获取该实例的全局访问点。


【视觉知识】单例模式
第一种

因为静态变量的生命周期跟整个应用程序的生命周期是一样的,所以可以定义一个私有的静态全局变量instance来保存该类的唯一实例;
必须提供一个全局函数访问获得该实例,并且在该函数提供控制实例数量的功能,即通过if语句判断instance是否已被实例化,
如果没有则可以同new创建一个实例;否则,直接向客户返回一个实例。
在这种经典模式下,没有考虑线程并发获取实例问题,即可能出现两个线程同时获取instance实例,且此时其为null时,就会出现两个线程分别创建了instance,违反了单例规则

private static Singleton instance = null;

private Singleton()

{

}

public static Singleton Instance

{

    get

    {

        if  (instance == null)

    {

            instance = new Singleton();

        }

        return instance;

    }

}

【视觉知识】单例模式

第二种

每次请求实例时都会获得锁定,因此性能会受到影响

private static Singleton instance = null;

private static readonly object padlock = new object();

Singleton()

{

}

public static Singleton Instance

{

    get

    {

        lock (padlock)

        {

            if (instance == null)

            {

                instance = new Singleton();

            }

            return instance;

        }

    }

}

【视觉知识】单例模式
第三种

使用的readonly关键可以跟static一起使用,用于指定该常量是类别级的,它的初始化交由静态构造函数实现,并可以在运行时编译。在这种模式下,无需自己解决线程安全性问题,CLR会给我们解决。
由此可以看到这个类被加载时,会自动实例化这个类,而不用在第一次调用GetInstance后才实例化出唯一的单例对象。

private static readonly Singleton instance = new Singleton();


static Singleton()

{

}

private Singleton()

{

}

public static Singleton Instance

{

    get

    {

        return instance;

    }

}

【视觉知识】单例模式
第四种

优雅写法是要用到.net 4.0里Lazy<T>



    public sealed class Singleton_Program
    {
        private static readonly Lazy<Singleton_Program> lazy = new Lazy<Singleton_Program>(() => new Singleton_Program());

        public static Singleton_Program Instance { get { return lazy.Value; } }

        private Singleton_Program()
        {
        }
    }


参考文献:

【1】C#单例模式. 游不动. cnblog


声明:部分图片及内容来源于网络。仅供读者学习交流之目的,如有不妥,请联系删除。



我知道你在看