内存管理的思考方式
<ul>
<li>自己生成的对象,自己持有</li>
<li>非自己生成的对象,自己也能持有</li>
<li>不在需要自己持有的对象时释放</li>
<li>非自己持有的对象无法释放</li>
</ul>
生成持有对象:alloc/new/copy/mutableCopy方法
持有对象:retain方法
释放对象:release方法
废弃对象:dealloc方法
这些有关OC的内存管理方法,实际上包含在Cocoa框架中.Cocoa框架类库的NSObject类负担内存管理的职责.
自己生成的对象,自己持有
alloc.new.copy.mutableCopy,allocMyObject.newThatObject.copyThis.mutableCopyYourObject
非自己生成的对象,自己也能持有
下面以NSMutableArray的array方法说明:
<pre>//获得非自己生成并持有的对象 id obj = [NSMutableArray array]; //取得对象存在,但自己不持有对象,使用retain方法可以持有对象. [obj retain];
</pre>
不需要自己持有的对象时释放
自己持有的对象,一旦不需要,持有者有义务释放该对象.释放使用release方法
<pre>//获得非自己生成并持有的对象 id obj = [NSMutableArray array]; //自己持有对象 [obj retain]; /* 释放对象 指向对象的指针仍然保留在变量obj中,貌似可以访问 但对象一经释放绝对不可访问 */ [obj release];
</pre>
如此,用alloc方法由自己生成并持有的对象就通过release方法释放了.自己生成而非自己所持有的对象,用retain持有,同样可以release释放.
用某个方法生成对象,并将其返回给该方法的调用方
<pre>-(id)allocObject { //自己生成并持有对象 id obj = [NSObject alloc]init; //自己持有对象 return obj; }
</pre>
那么调用NSMutableArray array
方法取得对象存在,自己不持有对象,又是如何实现的呢?
<pre>-(id)object { id obj = [NSObject alloc]init; [obj autorelease] //取得的对象存在,但自己不持有对象 return obj; }
</pre>
<strong>上例中,使用了autolease方法,可以使取得的对象存在,自己不持有对象.autolease提供这样的功能,使对象在超出指定生存范围时能自动正确的释放</strong>使用NSMutableArray类的array方法获取谁都不持有的对象,这类方法都是通过autolease而实现的.
<pre>`
id obj1= [obj0 object];
[obj1 retain];
`</pre>
无法释放非自己持有的对象
崩溃1 :取得的对象存在,自己不持有对象
<pre>id obj1= [obj0 object]; [obj1 release]; //释放了非自己持有的对象!程序崩溃
</pre>