reference counter 引用计数器

来源:互联网 发布:河池论坛网络问政电话 编辑:程序博客网 时间:2024/05/16 08:57

◆内存管理容易出现的问题
memory leak(内存泄漏):不需要的内存领域没有释放。
dangling pointer(空指针):参照已经释放的内存领域。

◆Objective-C的内存管理机制
reference counter : Objective-C 1.0~
garbage collection : Objective-C 2.0~

◆reference counter机制
一个对象可以有多个owner,该计数器保存了程序中该对象有几个owner的信息。
当对该实例的reference counter变为0,也就是没有owner时,dealloc将被调用,以释放该实例内存。

◆下面方法生成的对象会使reference counter+1
①allocXxxx
②newXxxx
③CopyXxxx
④调用retain方法
⑤当向某个集合类add某个对象,该集合类就成为该对象的owner
⑥retain属性的setter
也就是说,如果使用了以上的方法得到一个对象,你就获得了该对象的ownership。
每使用一次reference counter+1。

◆下面方法生成的对象会使reference counter-1
①release
②autorelease生成的对象在该autoreleasePool drain时
*详细请参照http://wp.me/p1h2Ti-6K
③当从某个集合类remove某个对象时,就会释放该ownership
④当某个对象的父对象被释放时
也就是说,如果对某对象使用了以上的方法,你对该对象的ownership就会释放。
每使用一次就reference counter-1。

◆原则 ownership policy: 在不需要的时候释放你有ownership的对象。
所以,编码时,尽量做到
①类的retain属性,在类的dealloc方法中release。
②方法的本地变量,如果不需要作为返回值,则在不需要时release,或设置为autorelease。
③方法的本地变量,如果需要作为返回值,则设置为autorelease。
④在不需要ownership的时候,尽量使用convenience constructors方法构建该对象。
⑤在产生大量对象或大对象的循环中,使用autorelease pools机制来及时释放内存。
*详细请参照http://wp.me/p1h2Ti-6K
※关于ownership的转移请参照http://wp.me/p1h2Ti-7m

>>>>>>>>>>>>>>>>>>>>>>>>>
☆weak reference
当两个对象互相参照时,如果都是对方的owner的话,就会产生死锁问题。这时候就需要weak reference。
可以使用assign关键字。对于该对象,不需要进行内存释放管理。
比如,一个父View通常有它的子Views的ownership,而子Views通常只有对父View的weak reference。Cocoa中常见的assign对象有
table data sources,
outline view items,
notification observers,
targets,
delegates等。
<<<<<<<<<<<<<<<<<<<<<<<<<

>>>>>>>>>>>>>>>>>>>>>>>>>
☆alloc和dealloc
alloc为类方法,为对象分配内存空间。
dealloc为实例方法,释放对象的内存空间。
<<<<<<<<<<<<<<<<<<<<<<<<<

>>>>>>>>>>>>>>>>>>>>>>>>>
☆retain属性的setter
NSObject  *example;
其自动生成的setterr如下:

- (void) setExample:(NSObject *) newObject{     if(example != newObject){         [example release];         example = [newObject retain];     } }

所以,使用setter的时候,同时获得了ownership。
<<<<<<<<<<<<<<<<<<<<<<<<<

>>>>>>>>>>>>>>>>>>>>>>>>>
☆不需要释放的对象
有一些对象不需要释放,例如:
 Class对象
 对象常量
<<<<<<<<<<<<<<<<<<<<<<<<<

0 0
原创粉丝点击