使用场景
需要频繁实例化然后销毁的对象
- 私有化构造器,保护对象的创建
- 在类内部创建一个私有化对象(实例)
- 创建一个公共方法返回这个实例,因为无法创建对象,所以这个方法一定是 static 的,所以改方法返回的实例也是static 的。
代码实现
懒加载式
单例实例被延迟加载,即只有在真正使用的时候才会实例化一个对象并交给自己的引用。完美实现
/// <summary>/// Double-check locking/// </summary>public class Singleton2{private static Singleton2 instance = null;/// <summary>/// 通常用来加锁的字段是私有的/// </summary>private static object obj = new object();/// <summary>/// 单例模式私有化构造器/// </summary>private Singleton2() { }public static Singleton2 Instance{get{//首次检查用来提示性能,因为加锁比较耗时if (instance == null){lock (obj){if (instance == null){instance = new Singleton2();}}}return instance;}}}
内存饱满式
优点:这种写法比较简单,就是在类装载的时候就完成实例化。避免了线程同步问题。
缺点:在类装载的时候就完成实例化,没有达到Lazy Loading的效果。如果从始至终从未使用过这个实例,则会造成内存的浪费。完美实现
/// <summary>/// 借助Lazy特性的静态构造法/// </summary>public sealed class Singleton1{private static readonly Lazy<Singleton1> lazy = new Lazy<Singleton1>(() => new Singleton1());public static Singleton1 Instance { get { return lazy.Value; } }/// <summary>/// 单例模式私有化构造器/// </summary>private Singleton1() { }public void Demo(){Console.WriteLine("Demo");}}
参考文档
https://www.cnblogs.com/zhaoshujie/p/14323654.html 单例模式的六种实现
