1.objective-c中,对象的生命周期通过 引用计数来标示,当使用 alloc,new方法或通过copy消息时,引用计数就会加一,通过retain方法可以为对象再增加引用计数,要减少对象的引用计数,可以向该对象发送一条release消息。要获得对象引用对象的引用数量时,可以向对象发送retainCount消息来获取数量。
当引用计数0时,会调用dealloc方法销毁对象。
2.对象的自动释放
使用NSAutoreleasePool对象,可以创建一个自动释放池,给对象发送一个autorelease消息时,就可以将该对象放入到池中,当池被销毁时(即池对象调用了release方法),池中所有的对象都会被销毁。
*创建一个NSAutoreleasePool对象时,同样会有个引用计数指向该对象,并且值为1,所以当这个NSAutoreleasePool对象调用了release方法时,引用计数减为0,objective-c 就会去调用dealloc方法,销毁该池对象。
以下为自动释放池的示例:
#import <Foundation/Foundation.h> @interface RetainTracker : NSObject @end @implementation RetainTracker -(id) init{ if(self=[super init]){ NSLog(@"init: Retain count of %d",[self retainCount]); } return (self); }//init -(void) dealloc{ NSLog(@"dealloc called. Bye Bye."); [super dealloc]; }//dealloc @end //RetainTracker int main (int argc, const char * argv[]) { NSAutoreleasePool *pool=[[NSAutoreleasePool alloc] init]; RetainTracker *tracker=[RetainTracker new]; //count: 1 [tracker retain]; //count: 2 [tracker autorelease];//count: still 2 [tracker release];// count 1 NSLog(@"releasing pool"); [pool release];//gets nuked return 0; }
a.使用init方法,创建了一个自动释放池对象,并且该对象的引用计数为1;
b.当执行了 new 方法时,创建了一个对象,对象引用计数增加为1
c.retain方法使计数再加1
d.向对象发送autorelease消息,将该对象置入自动释放池中,此时不影响对象的引用计数
e.release方法使对象的引用计数减为1(在这个过程中,自动释放池对象的引用计数一直为1)
f. pool对象执行realse方法,引用计数减为0,池对象销毁,dealloc方法被调用。
执行的结果为
init: Retain count of 1 releasing pool dealloc called.Bye Bye
3.Cocoa内存管理规则:
总结起来其实就一句话: 如果我们使用了new,alloc或copy方法获得一个对象,则我们必须释放或自动释放该对象。
4.objective-c2.0中引入了垃圾回收机制,可以通过设置工程属性里,build选项卡中的Required[-fobjc-gc-only]来启用