本文共 1741 字,大约阅读时间需要 5 分钟。
Singleton模式要求一个类有且仅有一个实例,并且提供了一个全局的访问点。
1. 单线程时方法
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | public sealed class Singlton { static Singlton instance = null ; Singlton() { } public static Singlton Instance { get { if (instance == null ) { return new Singlton(); } return instance; } } } |
这句if (instance == null)不是线程安全的,可能产生多个实例。
2.线程安全的
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | public sealed class Singlton { static Singlton instance = null ; static readonly object o = new object (); Singlton() { } public static Singlton Instance { get { lock (o) { if (instance == null ) { return new Singlton(); } return instance; } } } } |
对象实例由最先进入的那个线程创建,后来的线程在进入时(instence == null)为假,不会再去创建对象实例了。但是这种实现方式增加了额外的开销,损失了性能。
3. 双重锁定
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 | public sealed class Singlton { static Singlton instance = null ; static readonly object o = new object (); Singlton() { } public static Singlton Instance { get { if (instance == null ) { lock (o) { if (instance == null ) { return new Singlton(); } } } return instance; } } } |
避免了每个 Instance 属性方法的调用中都出现独占锁定。
4. 静态初始化
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | public sealed class Singlton { static readonly Singlton instance = new Singlton(); static Singlton() { } public static Singlton Instance { get { return instance; } } } |
5. 延迟静态初始化
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | public sealed class Singlton { static Singlton() { } public static Singlton Instance { get { return CreateSinglton.instance; } } class CreateSinglton { internal static readonly Singlton instance = new Singlton(); static CreateSinglton() { } } } |