load&initialize&单例模式
1、load方法:
1> 当类被引用进程序的时候会执行这个函数
2> 一个类的load方法不用写明[super load],父类就会收到调用,并且在子类之前。
3> Category的load也会收到调用,但顺序上在主类的load调用之后。
2、initialize方法:
1> initialize的自然调用是在第一次主动使用当前类的时候
2> 和load不同,即使子类不实现initialize方法,会把父类的实现继承过来调用一遍。注意的是在此之前,父类的方法已经被执行过一次了,同样不需要super调用。
3、load和initialize有很多共同特点,下面简单列一下:
1> 在不考虑开发者主动使用的情况下,系统最多会调用一次
2> 如果父类和子类都被调用,父类的调用一定在子类之前
3> 都是为了应用运行提前创建合适的运行环境
4> 在使用时都不要过重地依赖于这两个方法,除非真正必要
由于initialize的这些特点,使得其应用比load要略微广泛一些。可用来做一些初始化工作,或者单例模式的一种实现方案
初始化很简单在这里就不举例了,那么单例模式的实现在initialize里是怎么完成的呢?
static UserHelper * helper = nil;
+ (void)initialize {
if ([self class] == [UserHelper class]) {
helper = [[UserHelper alloc] init];
}
}
试想一下,这样是不是很简单的就实现单例模式呀
那么我们顺便来说一下单例模式吧,我的理解就是,一个类里只有一个实例对象,看一下比较官方的概念
单例模式是一种常用的软件设计模式。在它的核心结构中只包含一个被称为单例的特殊类。通过单例模式可以保证系统中一个类只有一个实例而且该实例易于外界访问,从而方便对实例个数的控制并节约系统资源。如果希望在系统中某个类的对象只能存在一个,单例模式是最好的解决方案。
单例的创建步骤
(1)创建类方法,返回对象实例.以shared default current开头。
(2)创建一个全局变量用来保存对象的引用
(3)判断对象是否存在,若不存在,创建对象
单例的几种实现方法
1> 非线程安全写法
static UserHelper * helper = nil;
+ (UserHelper *)sharedUserHelper {
if (helper == nil) {//判断对象是否存在,若不存在,创建对象
helper = [[UserHelper alloc] init];
}
return helper;
}
2> 线程安全写法1
static UserHelper * helper = nil;
+ (UserHelper *)sharedUserHelper {
@synchronized(self) {//加一个互斥锁,这样就不会再同时访问该方法的时候,创建两个实例,导致实现单例错误了,对上一种方法的完善
if (helper == nil) {
helper = [[UserHelper alloc] init];
}
}
return helper;
}
3>线程安全写法(苹果推荐,主要用这个,我们也最长用这个)
static UserHelper * helper = nil;
+ (UserHelper *)sharedUserHelper {
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
helper = [[UserHelper alloc] init];
});
return helper;
}
还有一种就是上面介绍的那种,创建单例的方法很多种哦~~你记住了几种呢?