Objective-C的Initialize初始化方法研究

來源:互聯網
上載者:User

這篇文章介紹了Objective-C比較底層的內容,主要講解initialize和init方法的區別。從這篇文章中我們不光可以瞭解Objective-C在初始化時所做的事情,更可以學習到一些如何研究Objective-C語言內部到底做了什麼的方法,這樣你也可以自己對更深層次的內容進行探尋。

 

Objective-C很有趣的一個地方是,它非常非常像C。實際上,它就是C語言加上一些其他擴充和一個已耗用時間(runtime)。

有了這個在每個Objective-C程式中都會起作用的附加已耗用時間,給了它一些動態特性。C和C++沒有已耗用時間,他們僅僅被編譯為完全按照代碼的順序去執行,不多也不少。

Objective-C中帶有已耗用時間的好處是,它可以在你的程式啟動並執行流程中進行參與。在Objective-C中,它包括檢查是否一個對象可以處理特定的訊息,如果不能處理,它就協助你自動調用其他特定的方法去完成。

 

initialize不是init

已耗用時間的行為之一就是initialize。雖然看起來有點像大家常見的init,但是他們並不相同。

在程式運行過程中,它會在你程式中每個類調用一次initialize。這個調用的時間發生在你的類接收到訊息之前,但是在它的超類接收到initialize之後。

舉個例子,比如一個叫做Duck的類:

 

#import "Duck.h"; @implementation Duck +(void) initialize {        NSLog(@"Duck initialize");} -(void) init {        NSLog(@"Duck init");}@end

 

我們在這裡記錄initialize和init調用的時間。

我們建立三個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 initialize

2008-03-23 20:03:25.872 initialize_example[30253:10b] Duck init

2008-03-23 20:03:25.873 initialize_example[30253:10b] Duck init

2008-03-23 20:03:25.873 initialize_example[30253:10b] Duck init

我們可以看到,雖然我們建立了3個Duck的執行個體,但是 initialize僅僅被調用了一次。我們也可以看到,直到我們建立了一個Duck的執行個體,initialize才被調用。

但是如果Duck有一個子類的話,比如我們建一個Duck的子類叫做Chicken(好怪異……):

 

#import <cocoa /Cocoa.h>#import "Duck.h"@interface Chicken : Duck {}@end

 

注意Chicken這個類並沒有實現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調用(因為我們建立了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 initialize2008-03-23 20:13:34.699 initialize_example[30408:10b] Duck init2008-03-23 20:13:34.700 initialize_example[30408:10b] Duck init2008-03-23 20:13:34.700 initialize_example[30408:10b] Duck init2008-03-23 20:13:34.700 initialize_example[30408:10b] Duck initialize2008-03-23 20:13:34.701 initialize_example[30408:10b] Duck init

 

我們看到了4個Duck的init和2個Duck的initialize方法。這是怎麼回事呢?

看來如果一個子類沒有實現initialize方法,那麼超類會調用這個方法兩次,一次為自己,而一次為子類。

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

  1. +(void) initialize {

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

  3. }

現在看明白了:

[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:Duck2008-03-23 20:21:08.819 initialize_example[30513:10b] Duck init2008-03-23 20:21:08.820 initialize_example[30513:10b] Duck init2008-03-23 20:21:08.820 initialize_example[30513:10b] Duck init2008-03-23 20:21:08.820 initialize_example[30513:10b] Duck initialize class:Chicken2008-03-23 20:21:08.821 initialize_example[30513:10b] Duck init

 

如果你希望確定只用了initialize一次用來實現某些單獨啟動並執行工作,或者希望實現僅僅運行一次的方法,檢查一下[self class],才能確定是否是你希望做到的效果。

 

原文地址:

http://kupuk.com/2008/03/23/objective-c-initialize-method/

作者:Paul Robinson

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.