Singleton 单例模式

 Singleton(单例模式),也叫单子模式。是一种常用的软件设计模式。在应用这个模式时,单例对象的类必须保证只有一个实例存在。许多时候,整个系统值需要拥有一个全局对象,这样有利于协调系统整体的行为。例如,在某个服务器程序中,该服务器的配置信息存放在一个文件中,这些配置数据由一个单例对象统一读取,然后服务进程中的其他对再通过这个单例对象获取这些配置信息。这种方式简化了在复杂环境下的配置管理。

  实现单例模式的思路是:一个类能返回对象的一个实例(永远是同一个)和一个获得该实例的方法(必须是静态方法,通常使用getInstance这个名称);当调用这个方法时,如果类持有的实例不为空,就返回这个实例;如果类保持的实例为空,就创建该类的实例并将实例赋予该类保持的实例,从而限制用户只有通过该类提供的静态方法来得到该类的唯一实例。

  单例模式在多线程的应用场合下必须小心使用。当唯一实例尚未创建时,如果有两个线程同时调用创建方法,那么它们同时没有检测到唯一实例的存在,从而同时各自创建了一个实例,这样就有两个实例被构造出来,从未违反了单例模式中实例唯一的原则。解决这个问题的办法是为标记类是否已经实例化的变量提供一个互斥锁,虽然这样会降低效率。

   在Objective-C中创建一个单例的方法:

01.为单例类声明一个静态的实例变量,并且初始化它的值为nil; 

02.在获取实例的方法中,只有在静态实例为nil时,产生一个类的实例,这个实例通常称为共享的实例;

03.重写allocWithZone方法,用于确定:不能够使用其他的方法创建类的实例,限制用户只能通过获取实例的方法得到这个类的实例。所以,在allocWithZone方法中直接返回共享的类实例;

04.实现基本的协议方法copyWithZone:release、retain、retainCount和autorelease,用于保证单例具有一个正确的状态。

代码如下:

@implementation ClassA

static ClassA *classA = nil;

+(ClassA *)getClassA{

if(classA == nil){

classA = [[super allocWithZone:NULL]init];

}

return classA;

}

+(id)allocWithZone:(NSZone *) zone{

return [[self getClassA]retain ];

}

-(id)copyWithZone:(NSZone *) zone{

return self;

}

-(id) retain{

return self;

}

-(NSUInteger) retainCount{

return NSUIntegerMax;

}

-(void)release{

//不做处理;

}

-(id)autorelease{

return self;

}

}

原文地址:https://www.cnblogs.com/tanglimei/p/3020670.html