iOS中的load和initialize方法

注:本人是轉載供自己總結用, 做個筆記。

load方法。

在main函數前調用,如果一個類實現了load方法。在調用這個方法前會調用父類的load方法。而且這個過程是自動完成的。

// In Parent.m

+ (void)load {NSLog(@"Load Class Parent");}

// In Child.m,繼承自Parent

+ (void)load {NSLog(@"Load Class Child");}

// In Child+load.m,Child類的分類

+ (void)load {NSLog(@"Load Class Child+load");}

// 運行結果:/*

2016-02-01 21:28:14.379 load[11789:1435378] Load Class Parent

2016-02-01 21:28:14.380 load[11789:1435378] Load Class Child

2016-02-01 22:28:14.381 load[11789:1435378] Load Class Child+load

*/

initialize方法。

這個方法在第一次給某個類發送消息時調用,并且只調用一次。與load方法不同的是,即使子類沒有實現initialize方法,也會調用父類的方法。從而導致父類的方法調用兩遍。

// In Parent.m

+ (void)initialize {NSLog(@"Initialize Parent, caller Class %@", [selfclass]);}

// In Child.m

// 注釋掉initialize方法

// In main.m

Child *child = [Child new];

打印結果:

2016-02-0122:57:02.985load[12772:1509345]?

Initialize Parent, caller Class Parent

2016-02-0122:57:02.985load[12772:1509345]

?Initialize Parent, caller Class Child

? 總結:

1. load 和initialize都會在實例化對象之前調用,以main函數為分水嶺,前者在main函數之前,后者在main函數之后。

2. load和initialize方法都不會顯示的調用父類的方法而是自動調用,即使子類沒有initialize方法也會調用父類的方法,load方法不會調用父類。

3. load和initialize方法內部使用了鎖,因此他們是線程安全的。實現時要盡可能簡單,避免線程阻塞,不要再次使用鎖。

4. load方法常用來mehtod swizzle(方法協調),initialize常常用于初始化全局變量和靜態變量。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容