如果開發(fā)者只有在第一次調(diào)用存儲(chǔ)屬性時(shí)才能確定初始值,就需要使用延遲性實(shí)現(xiàn)。在IOS開發(fā)中無論Swift還是OC都應(yīng)用到了懶加載實(shí)現(xiàn)延時(shí),同時(shí)這樣可以加快程序在初始化時(shí)的速度以及盡可能的減少了內(nèi)存的浪費(fèi)。
在OC中:
一般都是重寫get方法時(shí),先判斷對(duì)象當(dāng)前是否為空,為空的話再去實(shí)例化對(duì)象
在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才會(huì)調(diào)用這些屬性的初始化,但是這里需要注意的是在懶加載過程中千萬(wàn)別用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是對(duì)屬性進(jìn)行延遲加載處理
lazy var myClassA:classA = classA();
func StartClassA() -> Void {
print( myClassA.tip)
}
}
let lazySwiftLazy = SwiftLazy()
lazySwiftLazy.StartClassA()
如果把最后一句注釋掉,效果圖如下

C8DA4824-A56B-42D6-A85D-D284DC08E26F.png
從上圖我們看出在lazySwiftLazy 初始化時(shí)雖然也調(diào)用了
lazy var myClassA:classA = classA();但是它的屬性myClassA并沒有進(jìn)行初始化,將代碼放開效果如下:
308DBAEE-7DA3-457F-9E26-CB63499D6C01.png
叢書出的語(yǔ)句可以看出,這個(gè)時(shí)候myClassA 才進(jìn)行了延遲加載的初始化,并且調(diào)用了起屬性
tip