您的位置:首页 > 移动开发 > IOS开发

IOS ARC 机制

2015-06-18 17:47 405 查看
iOS ARC 内存自动管理机制,目前,几乎好多的项目都会用ARC去,因为,它把内存释放这个体力活给干了,不过,虽然ARC很好,我们仍然不能完全把内存管理这回事儿抛在脑后。

ARC的工作原理:

ARC是一个编译前的步骤,它为我们的代码自动加上retain/release/autorelease语句。

ARC并不是垃圾收集,而且,引用计数也没有消失,只是变成自动而已。听起来像是事后追加的这么一个功能,不过,只要我们想一想Objective-C有多少功能是通过对源文件的预处理来实现的,就不会这么想了。

//下面是一个例子:

当我们用ARC的时候是这样

NSObject *obj = [[NSObject alloc]init];
// Do any additional setup after loading the view, typically from a nib.


用ARC是这样

NSObject *obj = [[NSObject alloc]init];
[obj release];


这里有官方的一些介绍

ARC 出现后随后又来了些新的规则:(来源

1. 对象的Alloc/Init创建对象的方法跟以前一样,但你一定不能调用retain/release/autorelease/retainCount。也不能通过selector偷偷地调用它们: 禁止使用@selector(retain)和@selector(release)。

2. dealloc方法

ARC为自动为你调用,一定不能直接调用dealloc。不过,如果你需要释放实例变量以外的资源,还是可以创建自定义的dealloc方法。但在这个方法里,不要调用[super dealloc]。因为ARC会帮你调。

3. 声明的属性

在ARC之前,我们是用@property指令中的assign/retain/copy参数来告诉编译器,如何管理这些属性的内存。用了ARC之后,这些参数就作废了,改用weak/strong这两个参数。

4. C结构中的对象指针

同样禁止使用。文档里建议不要把它们放在结构了,改放到类里去。否则ARC就不认识它们了。可能会出现一些移植上的问题。不过,ARC是可以以文件为单位来关闭的。参考下文的“引入不兼容ARC的代码”。

5. 以@autoreleasepool代替NSAutoReleasePool

兼容ARC的代码不能再使用NSAutoReleasePool对象,而要改用@autoreleasepool{}块。一个很好的例子:

int main(int argc, char *argv[])
{
@autoreleasepool {
return UIApplicationMain(argc, argv, nil, NSStringFromClass([ExampleAppDelegate class]));
}
}


其它

基于Zone的内存已经没了(在运行时里也没了)。不能再使用NSAllocateObject和NSDeallocateObject。

7.不能以new为开头给一个属性命名

OK !在说说ARC限定符-声明的属性,在我们开发的时候,我们会根据具体需求,去确定自己定自己使用的对象属性。

在ARC 下,一般都是strong,week,就说强应用,和弱引用,

strong 强引用 :
@property(strong)UIView *bgView;


相当与该对象的所有属性,也就是只有当该对象的strong 属性 释放掉后该对象才销毁。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: