構造函數: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]; }