单例使某个类在整个application的生命周期中只有一个实例,减少内存开销,方便统一管理和数据共享
@sychronized和dispatch_once 一样是线程安全,@synchronized的临界区代码可能在application生命周期中多次调用,而dispatch_once只会调用一次。dispatch的谓语必须是静态变量(类方法中无法使用全局变量),如果使用其他dispatch-once的结果是无法预知的。
单利用static修饰实例只会分配一次内存,且定义单例需要写类方法,只有静态变量才能在类方法中使用
1、在iOS中,所有对象的内存空间的分配最终都会调用allocWithZone方法;
如果想实现单例需要重写此方法;gcd(grand central dispach)(apple开发的一个多核编程的较新的解决方法)在gcd中专门提供了一个创建单例的方法;
+ (id)allocWithZone:(struct_NSZone*)zone
{
staticDemoObj*instance;
staticdispatch_once_tonceToken;
dispatch_once(&onceToken, ^{
instance = [superallocWithZone:zone];
});
returninstance;
}
+ (instancetype)sharedDemoObj
{
return[[selfalloc]init];
}
二、通过类方法创建
+(instancetype)shareDemoObj
{
staticDemoObj*obj =nil;
@synchronized(self){
if(obj==nil) {
obj = [[DemoObjalloc]init];
}
}
returnobj;
}
网友评论