转载

iOS中单例创建时不严格造成的问题和解决方法

这次项目中遇到了一个单例创建不严格造成了的问题。简单说来就是在有的地方使用了alloc创建了多个实例,当然如果严格按照接口的方法调用是不会有问题的,但是如果项目碰到有不太熟悉的人使用时在处理时就会出现使用其它的方法来创建实例,比如说用alloc,这样本打算使用相同的一个实例成了多个而达不到做这个模式的目的。

关于单例模式的实现主要是static调用后存储空间不释放的特性使得实例在程序的生命周期中保持唯一,根据这个特点,如果要解决前面的问题,可以在allocWithZone里调用接口sharInstance方法,在copyWithZone里直接返回实例,具体实现如下:

@implementation XNShareTool /**  步骤:  1.一个静态变量_inastance  2.重写allocWithZone, 在里面用dispatch_once, 并调用super allocWithZone  3.自定义一个sharedXX, 用来获取单例. 在里面也调用dispatch_once, 实例化_instance  -----------可选------------  4.如果要支持copy. 则(先遵守NSCopying协议)重写copyWithZone, 直接返回_instance即可.  */ /**第1步: 存储唯一实例*/ static XNShareTool *_instance; /**第2步: 分配内存孔家时都会调用这个方法. 保证分配内存alloc时都相同*/ +(id)allocWithZone:(struct _NSZone *)zone{  //调用dispatch_once保证在多线程中也只被实例化一次  static dispatch_once_t onceToken;  dispatch_once(&onceToken, ^{   _instance = [super allocWithZone:zone];  });  return _instance; } /**第3步: 保证init初始化时都相同*/ +(instancetype)sharedTool{  static dispatch_once_t onceToken;  dispatch_once(&onceToken, ^{   _instance = [[XNShareTool alloc] init];  });  return _instance; } /**第4步: 保证copy时都相同*/ -(id)copyWithZone:(NSZone *)zone{  return _instance; } @end 
正文到此结束
Loading...