在Objective-C中,NSObject是根類,而NSObject.h的頭文件中前兩個方法就是load和initialize兩個類方法,本篇文章就對這兩個方法做下說明和整理。(全部文字整理自http://www.cocoachina.com/ios/20150104/10826.html)
就像Application有生命周期回調方法一樣,在Objective-C的類被加載和初始化的時候,也可以收到方法回調,可以在適當的情況下做一些定制處理。而這正是load和initialize方法可以幫我們做到的。
+ (void)load;
+ (void)initialize;
可以看到這兩個方法都是以“+”開頭的類方法,返回為空。通常情況下,我們在開發過程中可能不必關注這兩個方法。如果有需要定制,我們可以在自定義的NSObject子類中給出這兩個方法的實現,這樣在類的加載和初始化過程中,自定義的方法可以得到調用。
1. load和initialize的共同特點
1.在不考慮開發者主動使用的情況下,系統最多會調用一次
2.如果父類和子類都被調用,父類的調用一定在子類之前
3.都是為了應用運行提前創建合適的運行環境
4.在使用時都不要過重地依賴于這兩個方法,除非真正必要
2. load方法相關要點
1.調用時機比較早,運行環境有不確定因素。具體說來,在iOS上通常就是App啟動時進行加載,但當load調用的時候,并不能保證所有類都加載完成且可用,必要時還要自己負責做auto release處理。
2.補充上面一點,對于有依賴關系的兩個庫中,被依賴的類的load會優先調用。但在一個庫之內,調用順序是不確定的。
3.對于一個類而言,沒有load方法實現就不會調用,不會考慮對NSObject的繼承。
4.一個類的load方法不用寫明[super load],父類就會收到調用,并且在子類之前。
5.Category的load也會收到調用,但順序上在主類的load調用之后。
6.不會直接觸發initialize的調用。
3. initialize方法相關要點
1.initialize的自然調用是在第一次主動使用當前類的時候(lazy,這一點和Java類的“clinit”的很像)。
2.在initialize方法收到調用時,運行環境基本健全。
3.initialize的運行過程中是能保證線程安全的。
4.和load不同,即使子類不實現initialize方法,會把父類的實現繼承過來調用一遍。注意的是在此之前,父類的方法已經被執行過一次了,同樣不需要super調用。
5.由于initialize的這些特點,使得其應用比load要略微廣泛一些。可用來做一些初始化工作,或者單例模式的一種實現方案。
我的總結
說了這么多,我想總結的是,我們如何去用這兩個方法:
1.這兩個方法的共同特點:都是在類的成員方法調用前調用,而且系統只調用一次.
2.根據以上特點,我們知道他們的使用場景是:將一些類的(或成員方法的)必要條件提前準備好,尤其是那些只需要使用一次的.
3.load和initialize的區別:調用initialize時,該類已經基本健全,而調用load時,由于調用較早,運行環境不確定,所以一般都會使用initialize方法.這些特點,使得initialize的應用比load要略微廣泛一些。可用來做一些初始化工作,或者單例模式的一種實現方案。