initialize

Objective-C很有趣的一個地方是唁影,它非常非常像C方篮。實際上付秕,它就是C語言加上一些其他擴展和一個運行時間(runtime)晾剖。有了這個在每個Objective-C程序中都會起作用的附加運行時間锉矢,給了它一些動態(tài)的特性。C和C++沒有運行時間齿尽,他們僅僅被編譯為完全按照代碼的順序去執(zhí)行沽损,不多也不少。Objective-C中帶有運行時間的好處是循头,它可以在你的程序運行的流程中進(jìn)行參與绵估。在Objective-C中,它包括檢查是否一個對象可以處理特定的消息卡骂,如果不能處理国裳,它就幫助你自動調(diào)用其他特定的方法去完成。initialize不是init運行時間的行為之一就是initialize全跨。雖然看起來有點像大家常見的init缝左,但是他們并不相同。在程序運行過程中螟蒸,它會在你程序中每個類調(diào)用一次initialize盒使。這個調(diào)用的時間發(fā)生在你的類接收到消息之前,但是在它的超類接收到initialize之后七嫌。舉個例子少办,比如一個叫做Duck的類:#import "Duck.h"; @implementation Duck +(void) initialize {? ? NSLog(@"Duck initialize");} -(void) init {? ? NSLog(@"Duck init");}@end我們在這里記錄initialize和init調(diào)用的時間。我們建立三個Duck對象的實例:NSLog(@"Hello, World!");Duck* duck1 = [[Duck alloc] init];Duck* duck2 = [[Duck alloc] init];Duck* duck3 = [[Duck alloc] init]; 看一下記錄:[Session started at 2008-03-23 20:03:25 -0400.]2008-03-23 20:03:25.869 initialize_example[30253:10b] Hello, World!2008-03-23 20:03:25.871 initialize_example[30253:10b] Duck initialize2008-03-23 20:03:25.872 initialize_example[30253:10b] Duck init2008-03-23 20:03:25.873 initialize_example[30253:10b] Duck init2008-03-23 20:03:25.873 initialize_example[30253:10b] Duck init我們可以看到诵原,雖然我們創(chuàng)建了3個Duck的實例英妓,但是initialize僅僅被調(diào)用了一次。我們也可以看到绍赛,直到我們創(chuàng)建了一個Duck的實例蔓纠,initialize才被調(diào)用。但是如果Duck有一個子類的話吗蚌,比如我們建一個Duck的子類叫做Chicken(好怪異……)#import#import "Duck.h"

@interface Chicken : Duck {

}

@end

注意Chicken這個類并沒有實現(xiàn)initialize方法腿倚。

如果我們同樣運行這個程序,但是加上一個Chicken的實例:

NSLog(@"Hello, World!");

Duck* duck1 = [[Duck alloc] init];

Duck* duck2 = [[Duck alloc] init];

Duck* duck3 = [[Duck alloc] init];

Chicken* chicken = [[Chicken alloc] init];

我們期待看到4個Duck的init調(diào)用(因為我們建立了3個Duck和一個Chicken)蚯妇,但是我們看到了這樣情況:

[Session started at 2008-03-23 20:13:34 -0400.]

2008-03-23 20:13:34.696 initialize_example[30408:10b] Hello, World!

2008-03-23 20:13:34.698 initialize_example[30408:10b] Duck initialize

2008-03-23 20:13:34.699 initialize_example[30408:10b] Duck init

2008-03-23 20:13:34.700 initialize_example[30408:10b] Duck init

2008-03-23 20:13:34.700 initialize_example[30408:10b] Duck init

2008-03-23 20:13:34.700 initialize_example[30408:10b] Duck initialize

2008-03-23 20:13:34.701 initialize_example[30408:10b] Duck init

我們看到了4個Duck的init和2個Duck的initialize方法敷燎。這是怎么回事呢暂筝?

看來如果一個子類沒有實現(xiàn)initialize方法,那么超類會調(diào)用這個方法兩次硬贯,一次為自己焕襟,而一次為子類。

我們在Duck的initialize類中記錄一下類名饭豹,這樣可以看得更清楚:

+(void) initialize {

NSLog(@"Duck initialize class:%@",[self class]);

}

現(xiàn)在看明白了:

[Session started at 2008-03-23 20:21:08 -0400.]

2008-03-23 20:21:08.816 initialize_example[30513:10b] Hello, World!

2008-03-23 20:21:08.818 initialize_example[30513:10b] Duck initialize class:Duck

2008-03-23 20:21:08.819 initialize_example[30513:10b] Duck init

2008-03-23 20:21:08.820 initialize_example[30513:10b] Duck init

2008-03-23 20:21:08.820 initialize_example[30513:10b] Duck init

2008-03-23 20:21:08.820 initialize_example[30513:10b] Duck initialize class:Chicken

2008-03-23 20:21:08.821 initialize_example[30513:10b] Duck init

如果你希望確定只用了initialize一次用來實現(xiàn)某些單獨運行的工作鸵赖,或者希望實現(xiàn)僅僅運行一次的方法,檢查一下[self class]拄衰,才能確定是否是你希望做到的效果它褪。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市翘悉,隨后出現(xiàn)的幾起案子列赎,更是在濱河造成了極大的恐慌,老刑警劉巖镐确,帶你破解...
    沈念sama閱讀 218,682評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異饼煞,居然都是意外死亡源葫,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,277評論 3 395
  • 文/潘曉璐 我一進(jìn)店門砖瞧,熙熙樓的掌柜王于貴愁眉苦臉地迎上來息堂,“玉大人,你說我怎么就攤上這事块促∪傺撸” “怎么了?”我有些...
    開封第一講書人閱讀 165,083評論 0 355
  • 文/不壞的土叔 我叫張陵竭翠,是天一觀的道長振坚。 經(jīng)常有香客問我,道長斋扰,這世上最難降的妖魔是什么渡八? 我笑而不...
    開封第一講書人閱讀 58,763評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮传货,結(jié)果婚禮上屎鳍,老公的妹妹穿的比我還像新娘。我一直安慰自己问裕,他們只是感情好逮壁,可當(dāng)我...
    茶點故事閱讀 67,785評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著粮宛,像睡著了一般窥淆。 火紅的嫁衣襯著肌膚如雪卖宠。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,624評論 1 305
  • 那天祖乳,我揣著相機與錄音逗堵,去河邊找鬼。 笑死眷昆,一個胖子當(dāng)著我的面吹牛蜒秤,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播亚斋,決...
    沈念sama閱讀 40,358評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼作媚,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了帅刊?” 一聲冷哼從身側(cè)響起纸泡,我...
    開封第一講書人閱讀 39,261評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎赖瞒,沒想到半個月后女揭,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,722評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡栏饮,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年吧兔,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片袍嬉。...
    茶點故事閱讀 40,030評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡境蔼,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出伺通,到底是詐尸還是另有隱情箍土,我是刑警寧澤,帶...
    沈念sama閱讀 35,737評論 5 346
  • 正文 年R本政府宣布罐监,位于F島的核電站吴藻,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏弓柱。R本人自食惡果不足惜调缨,卻給世界環(huán)境...
    茶點故事閱讀 41,360評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望吆你。 院中可真熱鬧弦叶,春花似錦、人聲如沸妇多。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,941評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至立莉,卻和暖如春绢彤,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蜓耻。 一陣腳步聲響...
    開封第一講書人閱讀 33,057評論 1 270
  • 我被黑心中介騙來泰國打工茫舶, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人刹淌。 一個月前我還...
    沈念sama閱讀 48,237評論 3 371
  • 正文 我出身青樓饶氏,卻偏偏與公主長得像,于是被迫代替她去往敵國和親有勾。 傳聞我的和親對象是個殘疾皇子疹启,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,976評論 2 355

推薦閱讀更多精彩內(nèi)容