如果開發(fā)者只有在第一次調(diào)用存儲屬性時才能確定初始值桑寨,就需要使用延遲性實(shí)現(xiàn)伏尼。在IOS開發(fā)中無論Swift還是OC都應(yīng)用到了懶加載實(shí)現(xiàn)延時,同時這樣可以加快程序在初始化時的速度以及盡可能的減少了內(nèi)存的浪費(fèi)尉尾。
在OC中:
一般都是重寫get方法時烦粒,先判斷對象當(dāng)前是否為空,為空的話再去實(shí)例化對象
在Swift中:
使用關(guān)鍵字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;
}
這樣只有在調(diào)用self.mutableArray
和self.classa
才會調(diào)用這些屬性的初始化代赁,但是這里需要注意的是在懶加載過程中千萬別用self.調(diào)用自己的懶加載的屬性扰她。
在Swift中懶加載:
使用關(guān)鍵字lazy代碼實(shí)現(xiàn):
class classA:NSObject{
var tip = "調(diào)用屬性"
override init() {
print("開始創(chuàng)建")
}
}
class SwiftLazy{
//使用lazy是對屬性進(jìn)行延遲加載處理
lazy var myClassA:classA = classA();
func StartClassA() -> Void {
print( myClassA.tip)
}
}
let lazySwiftLazy = SwiftLazy()
lazySwiftLazy.StartClassA()
如果把最后一句注釋掉,效果圖如下
從上圖我們看出在lazySwiftLazy 初始化時雖然也調(diào)用了
lazy var myClassA:classA = classA();
但是它的屬性myClassA并沒有進(jìn)行初始化芭碍,將代碼放開效果如下:叢書出的語句可以看出徒役,這個時候myClassA 才進(jìn)行了延遲加載的初始化,并且調(diào)用了起屬性
tip