内存管理的思考方式

内存管理的思考方式


  • 自己生成的对象,自己持有

  • 非自己生成的对象,自己也能持有

  • 不在需要自己持有的对象时释放

  • 非自己持有的对象无法释放

生成持有对象:alloc/new/copy/mutableCopy方法
持有对象:retain方法
释放对象:release方法
废弃对象:dealloc方法

这些有关OC的内存管理方法,实际上包含在Cocoa框架中.Cocoa框架类库的NSObject类负担内存管理的职责.

自己生成的对象,自己持有

alloc.new.copy.mutableCopy,allocMyObject.newThatObject.copyThis.mutableCopyYourObject

非自己生成的对象,自己也能持有

下面以NSMutableArray的array方法说明:

//获得非自己生成并持有的对象 id obj = [NSMutableArray array]; //取得对象存在,但自己不持有对象,使用retain方法可以持有对象. [obj retain];

不需要自己持有的对象时释放

自己持有的对象,一旦不需要,持有者有义务释放该对象.释放使用release方法

//获得非自己生成并持有的对象 id obj = [NSMutableArray array]; //自己持有对象 [obj retain]; /* 释放对象 指向对象的指针仍然保留在变量obj中,貌似可以访问 但对象一经释放绝对不可访问 */ [obj release];

如此,用alloc方法由自己生成并持有的对象就通过release方法释放了.自己生成而非自己所持有的对象,用retain持有,同样可以release释放.

用某个方法生成对象,并将其返回给该方法的调用方

-(id)allocObject { //自己生成并持有对象 id obj = [NSObject alloc]init; //自己持有对象 return obj; }

那么调用NSMutableArray array 方法取得对象存在,自己不持有对象,又是如何实现的呢?

-(id)object { id obj = [NSObject alloc]init; [obj autorelease] //取得的对象存在,但自己不持有对象 return obj; }

上例中,使用了autolease方法,可以使取得的对象存在,自己不持有对象.autolease提供这样的功能,使对象在超出指定生存范围时能自动正确的释放使用NSMutableArray类的array方法获取谁都不持有的对象,这类方法都是通过autolease而实现的.

`
id obj1= [obj0 object];
[obj1 retain];

`

无法释放非自己持有的对象

崩溃1 :取得的对象存在,自己不持有对象

id obj1= [obj0 object]; [obj1 release]; //释放了非自己持有的对象!程序崩溃

你可能感兴趣的:(内存管理的思考方式)