iOS设计模式之单例模式

单例模式:总是返回自己的同一个实例,它提供了对类的对象所提供的资源的全局訪问点,而且返回的实例仅仅能被实例化一次.

单例设计模式设计须要考虑的两个问题:

(1) :发起调用的对象不能以其它分配方式实例化单例对象,否则,就有可能创建单例类的多个实例

(2) :对单例对象实例化的限制应该与引用计数内存模型共存.


Singleton.h

#import <Foundation/Foundation.h>


@interface Singleton : NSObject


+(Singleton *) sharedInstance;


@end


Singleton.m

#import "Singleton.h"


@implementation Singleton


static Singleton *sharedSingleton = nil;


+(Singleton *) sharedInstance{

    

    if (sharedSingleton == nil) {

        //sharedSingleton = [[Singleton alloc] init];

        //     --------->>>>>(1)

        //sharedSingleton = [[super allocWithZone:NULL] init];

        /*

            这里使用 super而不适用self的原因是self已经重载了allocWithZone方法

            所以通过调用父类的方法,实现内存的分配

            事实上allocWithZone方法内部调用的是NSAllocateObject方法

        */

        //     --------->>>>>(2)

        sharedSingleton = [NSAllocateObject([self class], 0, NULL) init];

        /*

            第一个參数是 类的类型

            第二个參数是 用于索引的实例变量的额外字节数,总是 0

            第三个參数是 用于指定内存中分配的区域,一般为NULL,表示为默认区域

            这里不适用(1)而使用(2)的原因是处理无论是实例化Singleton还是子类,都适用

         */

    }

    return sharedSingleton;

}



/*

    调用类的allocWithZone传入NSZone參数,为即将产生的新对象分配空间

    重载的目的是当使用对象的alloc方法时不会产生新的实例

    由于 alloc方法事实上调用的就是 allocWithZone:NULL方法,防止因 alloc而产生其它的实例

 

 */

+(id) allocWithZone:(struct _NSZone *)zone{


    return [[self sharedInstance] retain];

}



/*

    这里重载copyWithZone的目的,是防止使用 copy 方法时产生其它的实例

 */

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

    

    return self;


}


-(id) retain{

    

    return self;

}


-(NSUInteger) retainCount{

    

    return NSUIntegerMax;

}


-(void) release{

    

    //什么也不做


}


-(id) autorelease{

    

    return self;

}


@end



posted @ 2017-08-11 08:36  wzjhoutai  阅读(105)  评论(0编辑  收藏  举报