几个问题
- iOS内存管理的机制是什么
- iOS内存管理什么情况会让对象引用计数增加
- 什么情况下会内存暴增,怎么解决
- 什么情况下会内存泄露,怎么解决
- 对象什么时候释放
- 自动释放池原理
- property关键字有哪些,代表什么含义
- block对象的内存管理
iOS内存管理机制
iOS的内存管理是通过引用计数机制,每次操作对象都会有相应的操作引用计数.当引用计数等于0,会给对象发送dealloc消息销毁对象
引用计数iOS内的实现是通过引用计数表
iOS内存管理什么情况会对象让引用计数会增加
- 一般创建对象的时候会让引用计数+1,如alloc/new/copy/mutableCopy
- 通过其他方法比如NSArray的array方法,NSDictionary的dictionary方法
- 对象被加入autoreleasePool引用计数会+1,但是我打印引用计数看了,并没有+1
- 全局的对象被block引用时候,引用计数+1,局部变量被引用时,引用计数增加数额不定。为什么数额不定?一种解释是因为retainCount值不精确,这种说法不对,因为在ARC下使用retainCount打印出来也是这个值。应该和block内部实现机制有关系
- retain方法,只能MRC下使用
- 被强指针指向的时候
什么情况下会内存暴增,怎么解决
循环创建一堆对象的时候,此时可以通过新增自动释放池解决
什么情况下会内存泄露,怎么解决
循环引用的情况,一般注意delegate修饰符用weak,block内部使用__weak修饰;
timer持有对象造成内存泄露,原因是runloop持有timer,timer持有对象,造成对象无法释放,通过中间间的方式可以解决。
对象什么时候释放
引用计数为0的时候
释放时机
如ARC下强指针指向对象,强指针生命周期结束时候对象会被释放;
自动加入自动释放池的对象,自动释放池收到runloop的通知,执行autoreleasepoolPop方法的时候
自动释放池原理
autoreleasepoolPage通过双链表的形式组成,详细另写一篇吧
property关键字有哪些,代表什么含义
property=ivar+getter+setter
如果自己实现getter和setter,属性修饰符就不起作用
默认属性修饰符是atomic,readwrit,assign
atomic能保证读写操作完整性,但不能说是线程安全
其中property在ARC下的内存修饰符是:
- assign修饰基础数据类型,弱引用,和weak的区别是对象被释放不会自动置为nil
- strong是强引用
- copy也是强引用,与strong区别是实现copy协议。copy协议涉及到可变不可变,深拷贝浅拷贝,自定义对象的copy协议,集合对象的copy,父类子类的copy协议实现,以及copy协议实现要用allocWithZone,copyWithZone。但是苹果好像放弃了zone的使用。
- weak弱引用,和assign区别是修饰对象,对象被释放会置为nil,实现方式是weak表
block对象的内存管理
1.注意三种block,其中stackblock的话需要copy一下给copy到堆上
2.block对象引用用弱引用,内部再强引用一下