3、 { get { if (instance == null) { instance = new SingleThread_Singleton(); } return instance; } } }以上代码在单线程情况下不会出现任何问题。但是在多线程的情况下却不是安全的。如两个线程同时运行到if (instance == null)判断
4、是否被实例化,一个线程判断为True后,在进行创建 instance = new SingleThread_Singleton();之前,另一个线程也判断(instance == null),结果也为True.这样就就违背了Singleton模式的原则(保证一个类仅有一个实例)。怎样在多线程情况下实现Singleton?(2)多线程Singleton实现: 1 class MultiThread_Singleton 2 { 3 private static volatile MultiThread_Singleton instance = nul
5、l; 4 private static object lockHelper = new object(); 5 private MultiThread_Singleton() { } 6 public static MultiThread_Singleton Instance 7 { 8 get 9 {10 if (instance == null)11 {第244页共244页12 lock (l
6、ockHelper)13 {14 if (instance == null)15 {16 instance = new MultiThread_Singleton();17 }18 }19 }20 return instance;21 }
7、 22 }23 此程序对多线程是安全的,使用了一个辅助对象lockHelper,保证只有一个线程创建实例(如果instance为空,保证只有一个线程instance = new MultiThread_Singleton();创建唯一的一个实例)。(DoubleCheck)请注意一个关键字volatile,如果去掉这个关键字,还是有可能发生线程不是安全的。volatile保证严格意义的多线程编译器在代码编译时对指令不进行微调。(3)静态Singleton实现3 class S