1.ARC IOS5.0以后才支持,IOS7.0以后,强制使用ARC。 2.ARC "Automatic" Refercences Counting 3.原理 依然使用引用计数器来管理内存,只是引用计数器的操作方式不同,由程序员发送消息转换为“编译器”帮我们自动发送消息,会在合适的位置自动加入retain、release、autorelease消息来进行计数管理,ARC是一种编译期语法。 4.使用ARC a.在ARC中,程序中不能出现retain、release、autorelease… b.在ARC中,程序不能在dealloc方法中显示调用父类的dealloc方法,一切在MRC中和内存相关的操作,ARC中都不能使用。 5.强引用 a.在程序中定义的引用,默认为强引用,所谓的强引用指向一个对象时,对象的引用计数器会自动加1,当引用超出作用域"{}",对象的引用计数器就会减1. b.定义强引用 __strong TRStudent* student = [TRStudent alloc]init]; c.当一个对象被引用指向时,此对象会隐式的retain一次,当强引用超出作用域时,指向的对象会隐式的发送release消息一次。 d.引用在使用的时候,会根据作用域的范围,自动做加1或减1的操作。 6.弱引用 a.定义弱引用 __weak TRStudent* student; b.仅仅就是指向对象,但不会隐式的发送retain消息,出了作用域也不会发送realse消息。 c.XXX当一个弱引用指向的对象,未销毁时,向对象发送消息,此弱引用会自动的变为强引用。(xcode4.x)版本 d.当一个弱引用指向的对象被销毁时,弱引用本身会自动的赋值为空。(nil) zeroing weak reference 四、内存管理ARC自动引用计数器管理 7.定义属性的时候,内存管理的描述 @property(nonatomic,strong)…; @property(nonatomic,weak)…;
重构ARC Student与Book的故事。
8.其它修饰关键字 @property(nonatomic,unsafe_unretained)int age; a. unsafe_unretained等同于"assgin",功能和__weak几乎一样,唯一不同,没有"zeroing weak reference",通常使用在基本数据类型。 b.__autoreleaseing 用在方法的返回值,将返回值的对象放入到自动释放池中。 +(id)student{ __autoreleaseing TRStudent* student = [[TRStudent alloc]init]; return student; } 9.dealloc方法 a.在ARC下,dealloc方法不允许调用父类的dealloc方法,当然也不允许向任何对象发送release消息,所以说dealloc方法几乎无用。 b.在一些特殊情况下需要重写dealloc方法。 1)在类中使用了C语言中的函数malloc分配内存。 2)在类中使用了C++语言中的函数new等方式创建内存空间。 此时需要在dealloc中对这些特殊的空间进行释放。 10.声明引用自动置空 a.在ARC下,如果定了一个引用没有赋值,编译会自动的初始化设置引用为空值。TRStudent* student; b.为了尊重C语言的规范,基本数据类型没有初始化值,依然是垃圾值。 11.MRC和ARC混用 a.把MRC的代码转换成ARC的代码(手动) retain=>strong release、autorelease、[super dealloc]删除掉。 b.xcode提供了自动将MRC转换成ARC的功能。 菜单栏(Edit)->Refacotor(重构)->Convert to Objective-C ARC c.在ARC项目中继续使用MRC编译的类 在编译选项中标识MRC文件即可 "-fno-objc-arc" d.在MRC项目中继续使用ARC编译的类 在编译选项中标识MRC文件即可 "-fobjc-arc"
|