概述
Singleton模式要求一个类有且仅有一个实例,并且提供了一个全局的访问点。这就提出了一个问题:如何绕过常规的构造器,提供一种机制来保证一个类只有一个实例?客户程序在调用某一个类时,它是不会考虑这个类是否只能有一个实例等问题的,所以,这应该是类设计者的责任,而不是类使用者的责任。
从另一个角度来说,Singleton模式其实也是一种职责型模式。因为我们创建了一个对象,这个对象扮演了独一无二的角色,在这个单独的对象实例中,它集中了它所属类的所有权力,同时它也肩负了行使这种权力的职责!
目的
保证一个类仅有一个实例,并提供一个访问它的全局访问点。
几种实现
1.简单实现
- class SingleInstance
- {
- static SingleInstance mInstance = new SingleInstance();
- SingleInstance()
- {
- }
- static SingleInstance()
- {
- }
- public static SingleInstance GetInstance()
- {
- if (mInstance != null)
- {
- return mInstance;
- }
- }
- }
2.线程安全实现:
- class SingletonWrrper
- {
- static SingletonWrrper mInstance = null;
- static readonly object objPack = new object();
- SingletonWrrper()
- {
- }
- public static SingletonWrrper GetInstance()
- {
- lock (objPack)
- {
- if (mInstance == null)
- {
- mInstance = new SingletonWrrper();
- }
- }
- return mInstance;
- }
- }
3.静态初始化:
class SingleInstance
{
static readonly SingleInstance mInstance = new SingleInstance();
SingleInstance()
{
}
static SingleInstance()
{
}
public static SingleInstance GetInstance()
{
return mInstance;
}
}
4.双重锁定:
class SingletonWrrper
{
static SingletonWrrper mInstance = null;
static readonly object objPack = new object();
SingletonWrrper()
{
}
public static SingletonWrrper GetInstance()
{
if (mInstance == null)
{
lock (objPack)
{
if (mInstance == null)
{
mInstance = new SingletonWrrper();
}
}
}
return mInstance;
}
}