IOS中OC和Swift的懒加载

2017-04-25  本文已影响120人  朦胧之眼

如果开发者只有在第一次调用存储属性时才能确定初始值,就需要使用延迟性实现。在IOS开发中无论Swift还是OC都应用到了懒加载实现延时,同时这样可以加快程序在初始化时的速度以及尽可能的减少了内存的浪费。
在OC中:
一般都是重写get方法时,先判断对象当前是否为空,为空的话再去实例化对象
在Swift中:
使用关键字lazy
在OC中使用:
定义属性:

@property(strong,nonatomic) NSMutableArray* mutableArray;

@property(strong,nonatomic) ClassA* classa;

其懒加载如下:

//懒加载初始化
-(NSMutableArray*) mutableArray
{
    if (_mutableArray == nil) {
        NSMutableArray* array_temp  = [[NSMutableArray alloc] initWithObjects:@"1",@"2",@"3", nil];
        
        _mutableArray = array_temp;
    }
    return _mutableArray;
}
//ClassA  泛指自定义的类
-(ClassA*) classa
{
    if (_classa == nil) {
        ClassA * classa_temp = [[ClassA alloc] init];
        _classa = classa_temp;
    }
    return _classa;
}

这样只有在调用self.mutableArrayself.classa才会调用这些属性的初始化,但是这里需要注意的是在懒加载过程中千万别用self.调用自己的懒加载的属性。
在Swift中懒加载:
使用关键字lazy代码实现:

class classA:NSObject{

    var tip = "调用属性"
    
   override init() {
        print("开始创建")
}
}
class  SwiftLazy{
   //使用lazy是对属性进行延迟加载处理
    lazy var myClassA:classA =  classA();
    func StartClassA() -> Void {
       print( myClassA.tip)
    }
}
let lazySwiftLazy = SwiftLazy()
lazySwiftLazy.StartClassA()

如果把最后一句注释掉,效果图如下

C8DA4824-A56B-42D6-A85D-D284DC08E26F.png
从上图我们看出在lazySwiftLazy 初始化时虽然也调用了lazy var myClassA:classA = classA();但是它的属性myClassA并没有进行初始化,将代码放开效果如下:
308DBAEE-7DA3-457F-9E26-CB63499D6C01.png
丛书出的语句可以看出,这个时候myClassA 才进行了延迟加载的初始化,并且调用了起属性tip
上一篇 下一篇

猜你喜欢

热点阅读