引用计数的相关内容数组
✓OC中内存管理机制就是引用计数安全
✓每一个对象都有引用计数,理论上若是对象的引用计数为0, 它就会自动释放对象,系统会回收它开辟的内存空间函数
✓在实际的开发中,存在多个指针指向同一个对象spa
2.影响引用计数的一些方法.net
使引用计数加1的方法(alloc,retain,copy,NSString的直接赋值字符串等)指针
retainCount是查看引用计数的次数的一个参考,不绝对.注意:当引用计数被释放为0时,retainCount打印出来仍是1,理论上是0orm
release 是释放的方法,即引用计数减1对象
注意:系统释放完了以后,理论上是会被销毁的,而后释放相应的内存,可是为了不野指针的现象,因此咱们在后面经常加入置空,即将指针地址nil内存
autorelease也是使引用计数减1,可是他不是当即执行,而是在指向了[pool autorelease]语句以后才会减1;固然若是用系统的自动释放池,或者本身创建自动释放池,在里面指向了引用计数加的时候,若是没有释放,而后会在自动释放池外,所有统一销毁开发
若是你想比较安全的使用对象,能够经过retain这个方法将这个对象持有,增长引用计数;若是不想使用这个对象,也就是销毁,可使用release,减小它的引用计数
特别强调:管理内存的核心就是使内存保持平衡.内存始终遵循的一大准则就是平衡原则
若是引用计数没有在保证平衡的原则,则会形成两个现象:内存泄露,野指针现象.
内存泄露:就是引用计数增长的次数大于减小的次数
注:main函数结束后,p指针只被释放了一次,能够理解为指针已被销毁,可是对象仍是存在的,只是经过指针没法找到对应的对象罢了,形成对象没法释放
野指针现象:就是引用计数释放的次数大于增长的次数
如上程序:引用计数加1,可是释放了两次,当释放完以后,及时将指针置空,再次释放,就能够有效地避免野指针的现象.
3.autoreleasepool的使用(前提是在MRC环境下使用)
注:若是对象p在自动释放池的内部调用autorelease,那么这个自动释放池就会自动记录release的信息,若是自动释放池销毁了,那么其中的东西也会被释放,在自动释放池中必须遵循平衡原则
4.系统自带 @autoreleasepool 相关的内容
这一个最主要的就是能够本身建立一个自动释放池,也可使用系统自带的,他最大的特色,就是全部使用的东西都会在池外统一释放
5.拷贝
拷贝分为深拷贝和浅拷贝两种.
6.深拷贝:拷贝的是对象,实际上就是建立一个新的对象
浅拷贝:拷贝的是指针,也就是对象的地址,它们操做的是同一个对象
注:拷贝的一大重点就是须要遵循NSCopying协议
深拷贝和浅拷贝最大的区别就是其实现方法
7.NSString的retainCount
建立字符串的对象,使用常量字符串赋值时,说明对象在常量区
可是当咱们使用initWithFormat时,建立的对象可能有两种可能:存放在堆区和常量区,若是字符串对象若是在常量区时,你使用了release,并不会对retainCount形成任何影响,可是,必须遵循内存平衡原则,不管在哪一个区,只要引用计数加1以后都必须相应的减1
8.copy和mutableCopy的区别
copy建立的对象是不变的
mutableCopy建立的对象是可变的
以数组为例
输出