Objective-C類的構造函數和析構函數

 構造函數:java

Objective-C是一門面向對象的語言,咱們在Objective-C中定義一個類時,總要提供一個初始化方法,通常你們都是這樣寫的:objective-c

- (id)init {  
    //調用父類方法,實例一個本類,涉及runtime,防止衝突,能夠在構造方法裏初始化一些數據等  
    self = [super init];  
    if (self) {  
        self.name = @"xxx";  
    }  
    return self;  
}

- (id)initWithString:(NSString *)aString
{ 
    [self init];
    self.name = aString;   
} 
  
- (id)initWithImage:(UIImage *)aImage
{ 
    [self init];
    self.image = aImage;   
}

這樣一段簡單的代碼,卻有不少能夠思考的問題:  編程

一、爲何要經過[super init]來調用父類的初始化方法,父類的初始化方法裏又執行了什麼東西?框架

首先,咱們知道對象繼承的概念,一個子類從父類繼承,那麼也要實現父類的全部功能,這就是is-a的關係,好比說狗是哺乳動物,那麼狗一定具備哺乳動物的特徵和功能。因此在子類的初始化方法中,必須首先調用父類的初始化方法,以實現父類相關資源的初始化。例如咱們在初始化狗這一對象時,必須先初始化哺乳動物這一對象,並把結果賦予狗,以使狗知足屬於哺乳動物這一特徵。函數

典型的,在iOS下,全部的類都繼承於NSObject,而NSObject的init方法很簡單,就是return self。當父類的初始化完成以後,即self不爲nil的狀況下,就能夠開始作子類的初始化了。spa

 

在面向對象編程中,若是編寫一個類而沒有包含構造函數,這個類仍能編譯而且徹底能夠正常使用。若是類沒有提供顯式的構造函數,編譯器會提供一個默認的構造函數給你。除了建立對象自己,默認構造函數的惟一工做就是調用其超類的構造函數。在不少狀況下,這個超類是語言框架的一部分,如java中的 Object類,objective-c 中的NSObject類。代理

不管是何種狀況,在類中至少包含一個構造函數是一種很好的編程實踐,若是類中有屬性,好的實踐每每是初始化這些屬性。code

 

析構函數 對象

析構函數dealloc,對象從內存中銷燬前夕調用的函數blog

- (void)dealloc  
{  
    //析構函數是在對象徹底銷燬的時候自動調用  
    //對象銷燬的時候調用 計數器 retainCount = 0  
    //dealloc 不能夠人爲調用  
    //在dealloc裏清除成員變量,代理,監聽等  
    self.color = nil;  
    self.linePoints = nil;  
    [super dealloc];  
}
相關文章
相關標籤/搜索