原则函数
1. 谁建立,谁释放(相似于“谁污染,谁治理”)。若是你经过alloc、new或copy来建立一个对象,那么你必须调用release或autorelease。换句话说,不是你建立的,就不用你去释放。
例如,你在一个函数中alloc生成了一个对象,且这个对象只在这个函数中被使用,那么你必须在这个函数中调用release或autorelease。若是你在一个class的某个方法中alloc一个成员对象,且没有调用autorelease,那么你须要在这个类的dealloc方法中调用release;若是调用了autorelease,那么在dealloc方法中什么都不须要作。spa
2. 除了alloc、new或copy以外的方法建立的对象都被声明了autorelease。指针
3. 谁retain,谁release。只要你调用了retain,不管这个对象是如何生成的,你都要调用release。有时候你的代码中明明没有retain,但是系统会在默认实现中加入retain。
不知道为何苹果公司的文档没有强调这个很是重要的一点,请参考范式7和第三章。code
范式
范式就是模板,就是依葫芦画瓢。因为不一样人有不一样的理解和习惯,我总结的范式不必定适合全部人,但我能保证照着这样作不会出问题。对象
1 建立一个对象。blog
ClassA *obj1 = [[ClassA alloc] init];
2 建立一个autorelease的对象。文档
ClassA *obj1 = [[[ClassA alloc] init] autorelease];
3 Release一个对象后,当即把指针清空。(顺便说一句,release一个空指针是合法的,但不会发生任何事情)it
[obj1 release];
obj1 = nil;
4 指针赋值给另外一个指针。io
ClassA *obj2 = obj1; [obj2 retain]; //do something [obj2 release]; obj2 = nil;
5 在一个函数中建立并返回对象,须要把这个对象设置为autorelease模板
ClassA *Func1(){ ClassA *obj = [[[ClassA alloc]init] autorelease]; return obj; }
6 在子类的dealloc方法中调用基类的dealloc方法
-(void) dealloc{ … [super dealloc]; }
7 在一个class中建立和使用property。
声明一个成员变量: ClassB *objB; 声明property,加上retain参数: @property (retain) ClassB* objB; 定义property: @synthesize objB; 除了dealloc方法之外,始终用.操做符的方式来调用property: self.objB 或者objA.objB 在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 给这个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; }