iOS内存管理

几个问题

  • iOS内存管理的机制是什么
  • iOS内存管理什么情况会让对象引用计数增加
  • 什么情况下会内存暴增,怎么解决
  • 什么情况下会内存泄露,怎么解决
  • 对象什么时候释放
  • 自动释放池原理
  • property关键字有哪些,代表什么含义
  • block对象的内存管理

iOS内存管理机制

iOS的内存管理是通过引用计数机制,每次操作对象都会有相应的操作引用计数.当引用计数等于0,会给对象发送dealloc消息销毁对象

引用计数iOS内的实现是通过引用计数表

iOS内存管理什么情况会对象让引用计数会增加

  1. 一般创建对象的时候会让引用计数+1,如alloc/new/copy/mutableCopy
  2. 通过其他方法比如NSArray的array方法,NSDictionary的dictionary方法
  3. 对象被加入autoreleasePool引用计数会+1,但是我打印引用计数看了,并没有+1
  4. 全局的对象被block引用时候,引用计数+1,局部变量被引用时,引用计数增加数额不定。为什么数额不定?一种解释是因为retainCount值不精确,这种说法不对,因为在ARC下使用retainCount打印出来也是这个值。应该和block内部实现机制有关系
  5. retain方法,只能MRC下使用
  6. 被强指针指向的时候

什么情况下会内存暴增,怎么解决

循环创建一堆对象的时候,此时可以通过新增自动释放池解决

什么情况下会内存泄露,怎么解决

循环引用的情况,一般注意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对象引用用弱引用,内部再强引用一下

你可能感兴趣的:(iOS内存管理)