OC使用引用计数来管理内存,每个继承NSObject的对象,内部都维护了一个引用计数器retainCount。当对象创建时(调用alloc或者new)引用计数器会+1, 手动调用retain()方法能够使引用计数器+1。手动调用release()方法能够使引用计数器-1,当引用计数器为0时,对象会自己主动调用"析构函数" dealloc()方法来回收资源和释放内存。

这样当一个对象被多个地方使用和管理时,能够通过retain()将引用计数器+1,来获取使用权限(防止其它使用者释放该对象)。用完了之后再通过调用release()将引用计数器-1来放弃使用权限(此时假设引用计数器为0,说明没有其它地方再使用该对象了。直接会被释放。假设引用计数器不为0,则证明还有其它地方再使用这个对象,该对象不会被释放)。

这是一种设计很优雅的内存管理机制,谁使用谁retain()用完之后release(),假设已经没有人使用它了。引用计数器为0,则释放掉。

//
// Goods.h
// 08_Retain&&Release
//
// Created by apple on 14-11-12.
// Copyright (c) 2014年 cc. All rights reserved.
// #import <Foundation/Foundation.h> @interface Goods : NSObject @property int price; /**
* dealloc方法,对象释放时会调用。用于资源的回收,相当于C++中的析构函数
* dealloc方法须要重写父类的方法,实现释放当前类的资源
*/
- (void)dealloc; @end
//
// Goods.m
// 08_Retain&&Release
//
// Created by apple on 14-11-12.
// Copyright (c) 2014年 cc. All rights reserved.
// #import "Goods.h" @implementation Goods - (void)dealloc { //TODO: 释放资源码 NSLog(@"%@被释放了", self); //须要调用父类来释放对象
[super dealloc];
} @end
//
// main.m
// 08_Retain&&Release
//
// Created by apple on 14-11-12.
// Copyright (c) 2014年 cc. All rights reserved.
// #import <Foundation/Foundation.h>
#import "Goods.h" int main(int argc, const char * argv[]) { @autoreleasepool { //当调用alloc或者new创建一个OC对象时,引用计数+1
Goods* pGoods = [[Goods alloc] init];
//输出: 1
NSLog(@"retainCount=%lu", (unsigned long)[pGoods retainCount]); //调用retain时引用计数+1
[pGoods retain];
//输出: 2
NSLog(@"retainCount=%lu", (unsigned long)[pGoods retainCount]); //调用release时引用计数-1
[pGoods release];
//输出: 1
NSLog(@"retainCount=%lu", (unsigned long)[pGoods retainCount]); //调用release时引用计数-1,此时retainCount为0。内存将被释放。自己主动调用realloc来释放资源和内存
[pGoods release]; }
return 0; }

05-16 01:03