我们这里重点讨论的是线程安全,而不是单例的严格实现(若需要严格实现还需要复写一些方法,更改一些实现代码):
gcd实现:
static AccountManager *sharedAccountManagerInstance = nil;
+ (AccountManager *)sharedManager {
static dispatch_once_t predicate; dispatch_once(&predicate, ^{
sharedAccountManagerInstance = [[AccountManager alloc] init];
});
return sharedAccountManagerInstance;
}
利用系统提供的能力来实现,此处保证^{
sharedAccountManagerInstance = [[self alloc] init];
});在应用程序的生命周期里只被执行一次;若sharedAccountManagerInstance被外面被手动释放(arc下无法手动release不存在此问题),则会造成崩溃,崩溃原因时野指针访问,系统错误码应为exc_bad_access.因此调用获取单例对象者是不应该释放该单例对象的,这点需要严格遵守,单例本身的设计思想也包含了这一点。
双检锁实现:增加的外围检查用来提高效率。
static AccountManager *sharedAccountManagerInstance = nil;
+ (AccountManager *)sharedManager
{
if(sharedAccountManagerInstance == nil)
{
@synchronized (self){
if (sharedAccountManagerInstance == nil)
{
sharedAccountManagerInstance = [[AccountManager alloc] init];
}
}
}
return sharedAccountManagerInstance;
}