二口訣與範式函數
1 口訣。spa
1.1 誰建立,誰釋放(相似於「誰污染,誰治理」)。若是你經過alloc、new或copy來建立一個對象,那麼你必須調用release或autorelease。換句話說,不是你建立的,就不用你去釋放。
例如,你在一個函數中alloc生成了一個對象,且這個對象只在這個函數中被使用,那麼你必須在這個函數中調用release或autorelease。若是你在一個class的某個方法中alloc一個成員對象,且沒有調用autorelease,那麼你須要在這個類的dealloc方法中調用release;若是調用了autorelease,那麼在dealloc方法中什麼都不須要作。指針
1.2 除了alloc、new或copy以外的方法建立的對象都被聲明瞭autorelease。對象
1.3 誰retain,誰release。只要你調用了retain,不管這個對象是如何生成的,你都要調用release。有時候你的代碼中明明沒有retain,但是系統會在默認實現中加入retain。不知道爲何蘋果公司的文檔沒有強調這個很是重要的一點,請參考範式2.7和第三章。文檔
2 範式。
範式就是模板,就是依葫蘆畫瓢。因爲不一樣人有不一樣的理解和習慣,我總結的範式不必定適合全部人,但我能保證照着這樣作不會出問題。it
2.1 建立一個對象。io
ClassA *obj1 = [[ClassA alloc] init];模板
2.2 建立一個autorelease的對象。class
ClassA *obj1 = [[[ClassA alloc] init] autorelease];變量
2.3 Release一個對象後,當即把指針清空。(順便說一句,release一個空指針是合法的,但不會發生任何事情)
[obj1 release];
obj1 = nil;
2.4 指針賦值給另外一個指針。
ClassA *obj2 = obj1;
[obj2 retain];
//do something
[obj2 release];
obj2 = nil;
2.5 在一個函數中建立並返回對象,須要把這個對象設置爲autorelease
ClassA *Func1()
{
ClassA *obj = [[[ClassA alloc]init]autorelease];
return obj;
}
2.6 在子類的dealloc方法中調用基類的dealloc方法
-(void) dealloc
{
…
[super dealloc];
}
2.7 在一個class中建立和使用property。
2.7.1 聲明一個成員變量。
ClassB *objB;
2.7.2 聲明property,加上retain參數。
@property (retain) ClassB* objB;
2.7.3 定義property。(property的默認實現請看第三章)
@synthesize objB;
2.7.4 除了dealloc方法之外,始終用.操做符的方式來調用property。
self.objB 或者objA.objB
2.7.5 在dealloc方法中release這個成員變量。
[objB release];
示例代碼以下(詳細代碼請參考附件中的memman-property.m,你須要特別留意對象是在什麼時候被銷燬的。):
@interface ClassA : NSObject
{
ClassB* objB;
}
@property (retain) ClassB* objB;
@end
@implementation ClassA
@synthesize objB;
-(void) dealloc
{
[objB release];
[super dealloc];
}
@end
2.7.6 給這個property賦值時,有手動release和autorelease兩種方式。
void funcNoAutorelease()
{
ClassB *objB1 = [[ClassB alloc]init];
ClassA *objA = [[ClassA alloc]init];
objA.objB = objB1;
[objB1 release];
[objA release];
}
void funcAutorelease()
{
ClassB *objB1 = [[[ClassB alloc]init] autorelease];
ClassA *objA = [[[ClassA alloc]init] autorelease];
objA.objB = objB1;
}