ObjC内存管理的原则和范式

原则函数

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;
}

 
相关文章
相关标签/搜索