OC 内存管理
2016-02-29 00:00
330 查看
引用计数的相关内容
✓OC中内存管理机制就是引用计数
✓每个对象都有引用计数,理论上如果对象的引用计数为0, 它就会自动释放对象,系统会回收它开辟的内存空间
✓在实际的开发中,存在多个指针指向同一个对象
2.影响引用计数的一些方法
使引用计数加1的方法(alloc,retain,copy,NSString的直接赋值字符串等)
retainCount是查看引用计数的次数的一个参考,不绝对.注意:当引用计数被释放为0时,retainCount打印出来还是1,理论上是0
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创建的对象是可变的
以数组为例
输出
✓OC中内存管理机制就是引用计数
✓每个对象都有引用计数,理论上如果对象的引用计数为0, 它就会自动释放对象,系统会回收它开辟的内存空间
✓在实际的开发中,存在多个指针指向同一个对象
2.影响引用计数的一些方法
使引用计数加1的方法(alloc,retain,copy,NSString的直接赋值字符串等)
retainCount是查看引用计数的次数的一个参考,不绝对.注意:当引用计数被释放为0时,retainCount打印出来还是1,理论上是0
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创建的对象是可变的
以数组为例
输出
相关文章推荐
- iOS中通过设置CSS改变WebView字体大小,颜色,背景颜色
- 手机版VPS英译中正在处理中
- Ubuntu 14.04 配置 Nginx, MySQL and PHP 环境
- ftp 实现文件的上传下载以及列出文件列表
- git 个人经验总结
- linux文本编辑nano
- Ubuntu文本编辑时vi和nano命令的区别(建议使用nano)
- Linux 执行命令source或./
- Linux下修改.bash_profile 文件改变PATH变量的值
- Linux下SHELL的PS1变量简介
- Linux中set,env和export这三个命令的区别
- js中Date.parse 转换类型 兼容性的错误
- 《2015互联网安全年报》,移动端成重灾区,黑灰产日益成熟
- java enum(枚举)的自定义方法的简单使用
- 低成本3G DTU无线数据传输模块
- Mac下的比较器工具DeltaWalker的试用期延长法
- Eclipse & IDEA 快捷键对比
- JVM调优总结
- spring跟QuartZ整合
- JavaWeb项目获取路径各种方法。