OC 内存管理

  1. 引用计数的相关内容数组

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建立的对象是可变的

以数组为例

输出

相关文章
相关标签/搜索