转载请注明出处:http://www.cnblogs.com/shamoyuu/p/OC_CG.html

最近学习了Objective-C语言(以下简称OC),其他的都还好,唯有它的内存管理让我不知所措。因为OC跟我熟悉的Java、C#、js语言不同。Java,C#和js都是自动的垃圾回收,资源都是托管给虚拟机或者引擎,让他们定期查找不再使用的对象然后销毁。而OC的内存管理跟C和C++一样完全手动,我们程序员需要负责一个对象从生到死的每个过程,想想都心累。如果不做内存管理,不释放对象资源,那对象就会一直在内存中,很容易就内存溢出,程序闪退。

OC的内存管理对任何继承了NSObject的对象都适用,对其他的基本数据类型无效。

在代码块运行完成后,栈空间的变量会自动回收,但是堆空间的对象是无法自动回收的,只能手动回收。在Java中,如果没有任何变量指向一个对象的时候,就会被标记回收了。

OC里每个对象都有自己的引用计数器,它是一个整数,表示对象被引用的次数。如果计数器是0,则表示没有变量引用它,就会被回收。如果计数器不为0,那它就会一直在内存中,不会被回收。
当一个对象被销毁的时候,系统会自动调用对象的dealloc方法,一般我们会重写dealloc方法,用来释放相关的资源。
如果重写了dealloc方法,那一定要调用[super dealloc],并且放在最后,因为要先销毁子对象的资源,然后让父对象去销毁,这和创建对象的过程相反。
如果一个对象引用计数器变成0,那这个对象就被释放了,它就叫做僵尸对象。
如果一个指针指向一个僵尸对象,那么这个指针就叫野指针。
访问一个僵尸对象就会报EXC_BAD_ACCESS,很常见的错误,有点类似Java里的空指针。
应该在对象释放的时候,给指针赋值nil,nil就是空指针,而调用空指针的方法是不会报错的,跟Java里完全不一样。

当使用alloc、new和copy创建一个新对象的时候,新对象的引用计数器默认是1。

跟引用计数器相关的常用方法有这3个:

  • retain:引用计数器+1,并返回对象本身
  • release:引用计数器-1,没有返回值
  • retainCount:获得当前引用计数器的值

因为多个指针可以指向同一个对象,这样会使计数器加减混乱,所以我们在写OC代码的时候有两个原则:

  1. 谁创建,谁release
  2. 谁retain,谁release

总结一下就是“谁+1,谁-1”,只有这样,对象的引用计数器都可以正确地进行操作。

在OC里面有一个autoreleasepool(自动释放池)对象,它可以接管autorelease(自动释放)的对象,在这个自动释放池销毁的时候,它里面所有的自动释放对象都会调用release方法。

@autoreleasepool //创建了自动释放池对象
{
Animal *dog = [[[Animal alloc] init] autorelease]; [dog eat];
} //销毁了自动释放池对象

这样做的好处是显而易见的,可以自动帮我们把创建的对象的引用计数器减1,如果只有一个指针指向它的话(大多数情况都是如此),就不必我们手动release来释放了。

自从ios6有了ARC以后,内存管理就不用这么复杂了^_^

【其他】Objective-C 内存管理学习总结的更多相关文章

  1. Objective C内存管理之理解autorelease------面试题

    Objective C内存管理之理解autorelease   Autorelease实际上只是把对release的调用延迟了,对于每一个Autorelease,系统只是把该Object放入了当前的A ...

  2. C++内存管理学习笔记(5)

    /****************************************************************/ /*            学习是合作和分享式的! /* Auth ...

  3. C++内存管理学习笔记(6)

    /****************************************************************/ /*            学习是合作和分享式的! /* Auth ...

  4. C++内存管理学习笔记(7)

    /****************************************************************/ /*            学习是合作和分享式的! /* Auth ...

  5. Linux内存管理学习资料

    下面是Linux内存管理学习的一些资料. 博客 mlock() and mlockall() system calls. All about Linux swap space 逆向映射的演进 Linu ...

  6. C++内存管理学习笔记(4)

    /****************************************************************/ /*            学习是合作和分享式的! /* Auth ...

  7. C++内存管理学习笔记(3)

    /****************************************************************/ /*            学习是合作和分享式的! /* Auth ...

  8. C++内存管理学习笔记(2)

    /****************************************************************/ /*            学习是合作和分享式的! /* Auth ...

  9. C++内存管理学习笔记(1)

    /****************************************************************/ /*            学习是合作和分享式的! /* Auth ...

  10. c++内存管理学习纲要

    本系列文章,主要是学习c++内存管理这一块的学习笔记. 时间:6.7-21 之下以技术内幕的开头语,带入到学习C++内存管理的技术中吧: 内存管理是C++最令人切齿痛恨的问题,也是C++最有争议的问题 ...

随机推荐

  1. 锋利的jQuery笔记

    首先分清jQuery对象和DOM对象,这两者可相互转化,如: var $cr=$("#cr"); //jquery对象 var cr=$cr[0] ; //DOM对象 var cr ...

  2. ng机器学习视频笔记(一)——线性回归、代价函数、梯度下降基础

    ng机器学习视频笔记(一) --线性回归.代价函数.梯度下降基础 (转载请附上本文链接--linhxx) 一.线性回归 线性回归是监督学习中的重要算法,其主要目的在于用一个函数表示一组数据,其中横轴是 ...

  3. MUI 页面传值,因为用的是H5+ plus方法所以要在真机上才能测试出效果

    页面a.html <!doctype html> <html> <head> <meta charset="UTF-8"> < ...

  4. Hands-On Machine Learning with Scikit-Learn and TensorFlow---读书笔记

    去年在北京参加了一次由O'Reilly和Cloudera联合举办的大数据会议Strata Data Conference,并有幸获得了O'Reilly出版的Hands-On Machine Learn ...

  5. java导入项目有红色叹号

    原因:缺少jar包 解决:         选中项目  ->  右键  -> Build Path  -> Configer Builder Path  ->  删除掉有错的J ...

  6. es随想一

    一.安全问题 前段时间网上看到的,大量的MongoDB服务器和ElasticSearch服务器被黑客攻击,留下勒索信息. ElasticSearch的2种客户端连接方式,transport方式默认的9 ...

  7. BZOJ 1815: [Shoi2006]color 有色图 [Polya DFS 重复合并]

    传送门 题意: 染色图是无向完全图,且每条边可被染成k种颜色中的一种.两个染色图是同构的,当且仅当可以改变一个图的顶点的编号,使得两个染色图完全相同.问N个顶点,k种颜色,本质不同的染色图个数(模质数 ...

  8. BZOJ 3143: [Hnoi2013]游走 [概率DP 高斯消元]

    一个无向连通图,顶点从1编号到N,边从1编号到M. 小Z在该图上进行随机游走,初始时小Z在1号顶点,每一步小Z以相等的概率随机选 择当前顶点的某条边,沿着这条边走到下一个顶点,获得等于这条边的编号的分 ...

  9. Codevs 3990 [中国剩余定理]

    模板题 注意如何得到[a,b]区间范围内的解 #include <iostream> #include <cstdio> #include <cstring> #i ...

  10. BZOJ 3771: Triple [快速傅里叶变换 生成函数 容斥原理]

    题意:n个物品,可以用1/2/3个不同的物品组成不同的价值,求每种价值有多少种方案(顺序不同算一种) [生成函数]: 构造这么一个多项式函数g(x),使得n次项系数为a[n]. 普通型生成函数用于解决 ...