注:本人是轉載供自己總結用, 做個筆記。
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常常用于初始化全局變量和靜態變量。