一、单例模式(Slingleton Pattern)
单例模式是最简单的设计模式之一。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。
这种模式涉及到一个单一的类,该类负责创建自己的对象,同时确保只有单个对象被创建。这个类提供了一种访问其唯一的对象的方式,可以直接访问,不需要实例化该类的对象。
二、单例的特性
- 单例类只能有一个实例,并且有声明周期
- 单例类必须自己创建自己的唯一实例
- 单例类提供一个全局访问点,在任何地方都可以获取
当然,单例类除了带来的好处,也是伴随着风险的
-
如果你使用的是懒加载形式的单例,他的初始化就是不可控的,因为是在第一次访问的时候才创建
-
因为可以全局访问,所以如果使用不当,逻辑就会散落到各地,逻辑之间的引用会非常混乱
-
因为可以通过Instance获取实例对象,所以内部的成员变量就会暴露出来,从而带来被修改的风险
可能在项目初期或者项目较小的时候,大家没有什么感觉,但是随着项目规模增大,这些都是隐患。
三、如何回避风险
处理这些问题的方法可能很多,可以在各方面对它进行限制,例如:
-
首先在单例里增加初始化方法,然后在合适的时机主动去初始化这个单例,已达到控制其生命周期的目的
-
使用静态方法,这样就不会把实例暴露出来
-
严格控制API的数量和自身的职责
四、几种单例模式
懒汉模式:如果不调用则不会进行实例化
1 public class Slingleton_Pattern : MonoBehaviour 2 { 3 private static Slingleton_Pattern Instance; 4 5 public static Slingleton_Pattern _Instance() 6 { 7 if(Instance == null) 8 { 9 Instance = new Slingleton_Pattern(); 10 } 11 return Instance; 12 } 13 }
饿汉模式:系统运行则主动实例化
1 public class Slingleton_Pattern : MonoBehaviour 2 { 3 private static Slingleton_Pattern Instance = new Slingleton_Pattern(); 4 5 public static Slingleton_Pattern _Instance() 6 { 7 return Instance; 8 } 9 }
继承MonoBehaviour:便于其他模块调用,但非唯一性
1 public class Slingleton_Pattern : MonoBehaviour 2 { 3 private static Slingleton_Pattern Instance; 4 5 void Awake() 6 { 7 Instance = this; 8 } 9 10 public static Slingleton_Pattern _Instance() 11 { 12 return Instance; 13 } 14 }
其他
1 public class Slingleton_Pattern : MonoBehaviour 2 { 3 private static Slingleton_Pattern Instance = null; 4 5 public static Slingleton_Pattern _Instance 6 { 7 get 8 { 9 if (Instance == null) 10 { 11 Instance = FindObjectOfType(typeof(Slingleton_Pattern)) as Slingleton_Pattern; 12 } 13 return Instance; 14 } 15 } 16 }
五、总结
单例的使用风险是可以在任意处进行访问,并且开放了实例的访问权限,在项目庞大的时候滥用单例会导致引用逻辑混乱,所以我们在设计项目结构的时候,尽量让业务模块和自己模块的逻辑形成单向的访问,避免所有逻辑交叉访问,设计单例的时候,对单例做限制,防止外界获取单例的整个实例,只对外界开放一部分服务,这样便可以缓解使用单例模式带来的风险和危害。
***| 以上内容仅为学习参考、学习笔记使用 |***