IOS中OC和Swift的懶加載

如果開發(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.mutableArrayself.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

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容