单例模式:

在多线程的程序开发过程中经常会遇到单例模式[单件模式],它的特点是不是根据客户程序的调用而生成新的实例,而是控制某个类型的实例数量只有一个。也就是说,单例模式就是保证在整个应用程序的生命周期中,在任何时刻,被指定的类只有一个实例,并为客户程序提供一个获取该实例的全局访问点。

接下来看一个经典的单例模式:

public class SingleInstance
{
    private static SingleInstance _instance=null;
    
    private SingleInstance()
    {
    }
    
    public SingleInstance GetInstance()
    {
        if(null==_instance)
        {
            _instance=new SingleInstance();
        }
        
        return _instance;
    }
}
View Code

但是以上经典的单例模式并没有考虑到多线程并发的问题,以下这段代码是对上述代码的完善以解决多线程并发问题,多线程下的单例模式[Lazy 模式]:

public class SingleInstance
{
    private static SingleInstance _instance=null;
    
    private static Object _lock=new Object();
    
    private SingelInstance()
    {
    }
    
    public SingleInstance GetInstance()
    {
        if(null==_instance)
        {
            lock(_lock)
            {
                if(null==_instance)
                {
                    _instance=new SingleInstance();
                }
            }
        }
        
        return _instance;
    }
}
View Code

还有另外一种饿汉模式,程序代码如下:

public class SingleInstance
{
    private static readonly SingleInstance _instance=new SingleInstance();
    
    private SingleInstance()
    {
    }
    
    public SingleInstance GetInstance()
    {
        return _instance;
    }
}
View Code

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

待续。。。

posted on 2015-02-02 15:15  边城愚者  阅读(1567)  评论(0编辑  收藏  举报