C产品在市场上有哪些独特优势?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1135个文字,预计阅读时间需要5分钟。
创建单例模式的原因主要是为了确保一个类只有一个实例,并提供一个全局访问点。这样做有以下几点好处:
1. 节省资源:单例模式减少了对象的创建,从而节省了内存和系统资源。
2.控制资源访问:通过单例模式,可以控制对资源的访问,避免多个实例同时操作资源导致的错误。
3.减少系统开销:创建和销毁对象需要消耗系统资源,单例模式减少了这些开销。
4.全局访问:单例模式使得类的一个实例可以被全局访问,便于管理和使用。
关于单例模式的具体实现和应用,可以参考以下内容:
- 实现方式:可以通过静态变量和静态方法实现单例模式。
- 应用场景:适用于需要全局访问点、资源有限、需要控制资源访问的场景,如数据库连接池、配置文件读取等。关于为什么需要创建单例?这里不过多介绍,具体百度知。
关于C# 创建单例步骤或条件吧
1、声明静态变量;
2、私有构造函数(无法实例化)
3、静态创建实例的方法;至于我这里的Singleton是sealed ,只是为了防止被继承,其实有私有构造函数足够了,这里只是为了代码可读性。
第一种常见的方式创建单例:
/// <summary> /// 不安全的单例 /// </summary> public sealed class Singleton { private static Singleton _Singleton; private Singleton() { } public static Singleton GetSingleton() { if (_Singleton == null) { _Singleton = new Singleton(); } return _Singleton; } }
注:为什么说是不安全的单例,多线程访问时可能会new多个对象...
第二种方式创建单例:
/// <summary> /// (多线程)安全单例 /// </summary> public sealed class Singleton { private static Singleton _Singleton; private static readonly object obj = new object(); private Singleton() { } public static Singleton GetSingleton() { if (_Singleton == null) { //加锁保护,在多线程下可以确保实例值被创建一次。缺点是每 次获取单例,都要进行判断,涉及到的锁和解锁比较耗资源。 lock (obj) { if (_Singleton == null) { _Singleton = new Singleton(); } } } return _Singleton; } }
注:为了解决上面第一种方式创建的不安全实例问题应用而生。
第三种方式创建单例:
/// <summary> /// 只读单例 /// </summary> public sealed class Singleton { private static readonly Singleton instance = new Singleton(); private Singleton() { } public static Singleton Instance { get { return instance; } } }
/// <summary> /// 基于上面的只读单例=自动属性只读单例(语法糖) /// </summary> public sealed class Singleton { private Singleton() { } public static Singleton Instance { get; } = new Singleton(); }
注:只读属性式=>借助readonly属性,instance只被初始化一次,同样达到了单例的效果。在引用函数执行第一句话之前,instance其实已经被赋值了,并不是预期的 只有到访问Instance变量时才创建对象。
第四种方式创建单例:
/// <summary> /// Singleton中加上静态构造函数。 /// </summary> public sealed class Singleton { public static readonly Singleton instance = new Singleton(); private Singleton() { Console.WriteLine("初始化1!"); } static Singleton() { } public static Singleton Instance { get { return instance; } } }
注:为了解决(第三种只读属性实例)在执行第一句代码之前,实例已经被初始化问题。
第五种方式创建单例:
/// <summary> /// 使用Lazy创建单例,默认是线程安全的 /// </summary> public sealed class Singleton { private static readonly Lazy<Singleton> instance = new Lazy<Singleton>(() => new Singleton());// private Singleton() { } public static Singleton Instance { get { return instance.Value; } } }
// 贴一下关于上面Lazy<T> s=new Lazy<T>()参数的定义; // 摘要: // 初始化System.Lazy`1类的新实例。 懒惰初始化时 // 发生时,使用指定的初始化函数和初始化模式。 // 参数: // valueFactory: // 被调用以生成延迟初始化值的委托是必需的参数 // // isThreadSafe: // 如果要使此实例可由多个线程同时使用,则为true; false //使此实例一次只能由一个线程使用。 public Lazy(Func<T> valueFactory, bool isThreadSafe);
以上就是C# 创建单例的多种方式的详细内容,更多关于c# 创建单例的资料请关注自由互联其它相关文章!
本文共计1135个文字,预计阅读时间需要5分钟。
创建单例模式的原因主要是为了确保一个类只有一个实例,并提供一个全局访问点。这样做有以下几点好处:
1. 节省资源:单例模式减少了对象的创建,从而节省了内存和系统资源。
2.控制资源访问:通过单例模式,可以控制对资源的访问,避免多个实例同时操作资源导致的错误。
3.减少系统开销:创建和销毁对象需要消耗系统资源,单例模式减少了这些开销。
4.全局访问:单例模式使得类的一个实例可以被全局访问,便于管理和使用。
关于单例模式的具体实现和应用,可以参考以下内容:
- 实现方式:可以通过静态变量和静态方法实现单例模式。
- 应用场景:适用于需要全局访问点、资源有限、需要控制资源访问的场景,如数据库连接池、配置文件读取等。关于为什么需要创建单例?这里不过多介绍,具体百度知。
关于C# 创建单例步骤或条件吧
1、声明静态变量;
2、私有构造函数(无法实例化)
3、静态创建实例的方法;至于我这里的Singleton是sealed ,只是为了防止被继承,其实有私有构造函数足够了,这里只是为了代码可读性。
第一种常见的方式创建单例:
/// <summary> /// 不安全的单例 /// </summary> public sealed class Singleton { private static Singleton _Singleton; private Singleton() { } public static Singleton GetSingleton() { if (_Singleton == null) { _Singleton = new Singleton(); } return _Singleton; } }
注:为什么说是不安全的单例,多线程访问时可能会new多个对象...
第二种方式创建单例:
/// <summary> /// (多线程)安全单例 /// </summary> public sealed class Singleton { private static Singleton _Singleton; private static readonly object obj = new object(); private Singleton() { } public static Singleton GetSingleton() { if (_Singleton == null) { //加锁保护,在多线程下可以确保实例值被创建一次。缺点是每 次获取单例,都要进行判断,涉及到的锁和解锁比较耗资源。 lock (obj) { if (_Singleton == null) { _Singleton = new Singleton(); } } } return _Singleton; } }
注:为了解决上面第一种方式创建的不安全实例问题应用而生。
第三种方式创建单例:
/// <summary> /// 只读单例 /// </summary> public sealed class Singleton { private static readonly Singleton instance = new Singleton(); private Singleton() { } public static Singleton Instance { get { return instance; } } }
/// <summary> /// 基于上面的只读单例=自动属性只读单例(语法糖) /// </summary> public sealed class Singleton { private Singleton() { } public static Singleton Instance { get; } = new Singleton(); }
注:只读属性式=>借助readonly属性,instance只被初始化一次,同样达到了单例的效果。在引用函数执行第一句话之前,instance其实已经被赋值了,并不是预期的 只有到访问Instance变量时才创建对象。
第四种方式创建单例:
/// <summary> /// Singleton中加上静态构造函数。 /// </summary> public sealed class Singleton { public static readonly Singleton instance = new Singleton(); private Singleton() { Console.WriteLine("初始化1!"); } static Singleton() { } public static Singleton Instance { get { return instance; } } }
注:为了解决(第三种只读属性实例)在执行第一句代码之前,实例已经被初始化问题。
第五种方式创建单例:
/// <summary> /// 使用Lazy创建单例,默认是线程安全的 /// </summary> public sealed class Singleton { private static readonly Lazy<Singleton> instance = new Lazy<Singleton>(() => new Singleton());// private Singleton() { } public static Singleton Instance { get { return instance.Value; } } }
// 贴一下关于上面Lazy<T> s=new Lazy<T>()参数的定义; // 摘要: // 初始化System.Lazy`1类的新实例。 懒惰初始化时 // 发生时,使用指定的初始化函数和初始化模式。 // 参数: // valueFactory: // 被调用以生成延迟初始化值的委托是必需的参数 // // isThreadSafe: // 如果要使此实例可由多个线程同时使用,则为true; false //使此实例一次只能由一个线程使用。 public Lazy(Func<T> valueFactory, bool isThreadSafe);
以上就是C# 创建单例的多种方式的详细内容,更多关于c# 创建单例的资料请关注自由互联其它相关文章!

