摘要: 单例的设计思想非常巧妙,是面向对象语言的一大优势,在需要全局资源共享的对象时,经常会用到这种设计模式。
iOS 中单例设计模式的浅析与用法
一、单例的作用
- 顾名思义,单例,即是在整个项目中,这个类的对象只能被初始化一次。它的这种特性,可以广泛应用于某些需要全局共享的资源中,比如管理类,引擎类,也可以通过单例来实现传值(通常使用的比较多一些)。UIApplication、NSUserDefaults等都是IOS中的系统单例。
二、单例的写法
- 单例的写法常用的有两种方式:
1.不考虑线程安全
+(MySingleNoSafeModel *)NoSafeSingle{
static MySingleNoSafeModel *single = nil;
if (!single) {
single = [[self alloc] init];
}
return single;
}
2.考虑线程安全
+(MySingleModel *)customSingle{
static MySingleModel *single = nil;
static dispatch_once_t predicate;
dispatch_once(&predicate, ^{
single = [[self alloc] init];
});
return single;
}
3.代码优化
- 通过上面的方法,我们已经可以使用类方法来得到这个单例,但很多时候,项目的工程量很大,还有可能会很多开发者同时参与一个项目的开发,为了安全与管理代码的方便,也为了给不是这个单例的创作者但会用到这个单例的开发人员一些提示,我们通常会重写一些方法:
- 首先我们自己实现一个alloc方法:
+(instancetype)myAlloc{
return [super allocWithZone:nil];
}
- 将我们的单例实现方法略作修改:
+(KingLPayManager *)sharedMamager{
static KingLPayManager * manager;
if (manager==nil) {
manager=[[KingLPayManager myAlloc] init];
}
return manager;
}
- 然后将一些视图实例化对象的方法重写:
+(instancetype)alloc{
NSAssert(0, @"这是一个单例对象,请使用+(KingLPayManager *)sharedMamager方法");
return nil;
}
+(instancetype)allocWithZone:(struct _NSZone *)zone{
return [self alloc];
}
-(id)copy{
NSLog(@"这是一个单例对象,copy将不起任何作用");
return self;
}
+(instancetype)new{
return [self alloc];
}
- 注意:这里的alloc使用了断言,让任何视图通过alloc创建对象的程序段断在此处,给程序员提示。copy方法这里只是简单的返回了原对象,并未做任何处理,打印信息给程序员提示。
- 本文的不足之处请多多指教,不胜感激!