
一般我们看到的ios单列中并未有加@synchronized(self),然而这样如果是多个线程同时来调用该单列,就会出现问题,创建的实例就不只是单列了,加了线程锁后让该单列始终只能返回一个实例,即单例:假如线程A来调用shareUserContext,这句话时候,会判断 segtonInstance == nil的情况,若没有创建则会创建实例,然而另外的一个线程B也来调用这句话时候,没有线程锁的情况会使其并发调用,即创建了两个实例;有了线程锁,让A创建好了实例后,那么B再来调用的时候就不会走进入if(segtonInstance == nil){}的括号,而直接执行 retrun segtonInstance这句,避免了重复创建实例。我认为线程锁的作用在于避免并发调用该方法,避免创建大于1个实例。
- #import <Foundation/Foundation.h>
- @interface UserContext : NSObject
- {
- }
- //创建单例的属性
- @property(nonatomic,copy) NSString *userName;
- @property(nonatomic,copy) NSString *userInfo;
- //创建单例方法
- +(id)shareUser;
- @end
- #import "UserContext.h"
- static UserContext *singInstance = nil;
- @implementation UserContext
- @synthesize userName;
- @synthesize userInfo;
- + (id)shareUser{
- @synchronized(self){
- if (singInstance == nil) {
- singInstance = [[[self class] alloc] init];
- }
- }
- return singInstance;
- }
- + (id)allocWithZone:(NSZone *)zone{
- if (singInstance == nil) {
- singInstance = [super allocWithZone:zone];
- }
- return singInstance;
- }
- - (id)copyWithZone:(NSZone *)zone{
- return singInstance;
- }
- - (id)retain{
- return singInstance;
- }
- - (oneway void)release{
- }
- - (id)autorelease{
- return singInstance;
- }
- @end
粗略的写了个demo,一个viewcontroller设置单例的属性,另外一个viewController访问单例的属性;单例的其他用法可以度娘或者骨骼下。
http://pan.baidu.com/share/link?shareid=171718&uk=2315407450
本文详细解释了在iOS开发中使用单例模式时为何需要在共享实例方法中加入@synchronized(self)关键字,以及其如何避免并发调用导致的实例创建冲突,确保单例模式的一致性和正确性。
3506

被折叠的 条评论
为什么被折叠?



