单例模式的书写
ARC
// 定义一个静态变量,在程序运行过程中只有1份
static id instance;
- ( instancetype ) init
{
static id obj = nil;
//onceToken初始为0
static dispatch_once_t onceToken;
// 确保只执行一次初始化代码
dispatch_once(&onceToken, ^{
//执行过后, onceToken变为-1,block内代码不再执行
if ((obj = [super init]))
{
// 加载资源
NSLog(@"加载资源");
}
});
return obj;
}
// 重写这个方法控制内存只分配一次
+(instancetype)allocWithZone:(struct _NSZone *)zone{
static dispatch_once_t onceToken;
// 里面的代码只会执行1次
dispatch_once(&onceToken, ^{
instance = [super allocWithZone:zone];
});
// 返回对象
return instance;
}
// 确保复制的对象还是同一个
- (id)copyWithZone:(NSZone *)zone
{
return self;
}
// 全局访问点
+ (instancetype)sharedAudioTool
{
return [[self alloc] init];
}
OC 中的单例
+ (instancetype)sharedManager
{
static id instance;
static dispatch_once_t onceToken;
NSLog(@"%ld", onceToken);
dispatch_once(&onceToken, ^{
instance = [[self alloc] init];
});
return instance;
}
根据OC单例 改写成 Swift 中的单例
static var instance: Tools?
static var token: dispatch_once_t = 0
class func sharedInstance() -> Tools
{
dispatch_once(&token) { () -> Void in
instance = Tools()
}
return instance!
}
OC调用swift,需要#import "单例-Swift.h",其中单例为Product Name 在 Swift 中 let 本身就是线程安全的
改进过的单例代码
static let instance = Tools()
class func sharedInstance() -> Tools
{
return instance
}
单例其实还可以更简单
最终形态
static let sharedTools = Tools()