iOS单例的创建与销毁

c#iOS单例的创建与销毁

单例:单例模式使一个类只有一个实例.单例是在使用过程,保证全局有唯一的一个实例.这样,才能满足统一管理的功能.例如,一个数据库,只需要全局统一的读取,写入操作.不要多个实例去读写.d单例是唯一实例,它不等同于一直伴随这app的生命周期.下面,我会从单例的创建与销毁去分析单例.

单例的创建

单例的创建分为arcmrc,两种模式下的创建.

  • ARC 下的创建
    1. 先定义一个静态的instance. static MyClass _instance;
    2. 重写allocWithZone方法.此方法为对象分配空间必须调用方法.
    3. 定一个个share的类方法.能够被全局调用的.此方法里需要考虑线程安全问题
    4. 如果需要copy,需要遵守NSCopying协议,以及在copyWithZone中,直接返回self;

例子


static Myclass _instance;
方法一:
+(id)shareInstance{ 
     @synchronized(self){
       if(_instance == nil)
            _instance = [MyClass alloc] init]; 
     }
     return _instance;
}


方法二:
+(id)shareInstance{
     static dispatch_once_t onceToken;
      dispatch_once(&onceToken, ^{
      if(_instance == nil)
            _instance = [MyClass alloc] init]; 
    });
     return _instance;
}
以上两种方法都是线程安全的.不过苹果官方现在提倡方法二.


This method exists for historical reasons; memory zones are no longer used by Objective-C. You should not override this method.

//重写allocWithZone,里面实现跟方法一,方法二一致就行.
+(id)allocWithZone:(struct _NSZone *)zone{
    static dispatch_once_t onceToken;
      dispatch_once(&onceToken, ^{
      if(_instance == nil)
            _instance = [MyClass alloc] init]; 
    });
     return _instance;
} 这个函数重写,是错误的。请读者注意。

//保证copy时相同
-(id)copyWithZone:(NSZone *)zone{  
    return _instance;  
} 

这样就是一个完整的单例,保证怎么创建都是唯一的.

  • MRC下的创建 创建过程跟ARC下步骤一样.不过要处理一些内存管理的函数.
//不需要计数器+1  
- (id)retain {  
    return self;  
}  
  
//不需要. 堆区的对象才需要  
- (id)autorelease {  
    return self;  
}  
  
//不需要  
- (oneway void)release {  
}  
  
//不需要计数器个数. 直接返回最大无符号整数  
- (NSUInteger)retainCount {  
    return UINT_MAX;  //参照常量区字符串的retainCount  
}

这样就能保证这个单例不会被无意释放.

单例的销毁

前面讲了单例的创建,但是有个别情况需要销毁单例.
下面分别从两种创建方法对应两种销毁形式.

方法一:
+(void)attemptDealloc{
    [_instance release]; //mrc 需要释放,当然你就不能重写release的方法了.
    _instance = nil;
}


方法二:
1. 必须把static dispatch_once_t onceToken; 这个拿到函数体外,成为全局的.
2.
+(void)attempDealloc{
    onceToken = 0; // 只有置成0,GCD才会认为它从未执行过.它默认为0.这样才能保证下次再次调用shareInstance的时候,再次创建对象.
    [_instance release];
    _instance = nil;
 }

以上两种方法即为销毁单例的方法.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 在iOS中有很多的设计模式,有一本书《Elements of Reusable Object-Oriented S...
    郑明明阅读 7,204评论 3 26
  • 一. ARC环境下的单例模式 单例模式的基本概念单例, 顾名思义, 即在整个程序中, 某一个类只有唯一一个实例, ...
    面糊阅读 4,088评论 0 50
  • @WilliamAlex大叔 前言 目前流行的社交APP中都离不开单例的使用,我们来举个例子哈,比如现在流行的"糗...
    Alexander阅读 5,932评论 6 28
  • 单例模式(SingletonPattern)一般被认为是最简单、最易理解的设计模式,也因为它的简洁易懂,是项目中最...
    成热了阅读 9,870评论 4 34
  • 一、深复制和浅复制的区别? 1、浅复制:只是复制了指向对象的指针,即两个指针指向同一块内存单元!而不复制指向对象的...
    iOS_Alex阅读 5,305评论 1 27

友情链接更多精彩内容