Objective-C高级编程 iOS 和 OS X 多线程和内存管理

第一章 自动引用计数

 1.1 定义

自动引用计数(ARC,Automatic Reference Counting)是指内存管理中对引用采取自动计数的技术。

*在 LLVm 编译器中设置 ARC 为有效状态,就无需再次键入 retain 或者是 release 代码。*

 1.2内存管理/引用计数

 1.2.1概要

引用计数的机制相当于开关房间的灯

1. 最早进入办公室的人开灯

2. 之后进入办公室的人,需要照明

3. 下班离开办公室的人,不需要照明

4. 最后离开办公室的人关灯(此时已无人需要照明)

判断是否有人还在办公室里,关键在于导入计数功能计算需要照明的人数。

1. 第一个人进入办公室,需要照明的人数加1.计数值从0编程了1,因此开灯

2. 之后每当有人进来,需要照明的人数就加1.

3. 每当有人下班离开,需要照明的人数就减1.

4. 最后一个人下班离开办公室时,需要照明的人数减1,计数值从1变成0,因此要关灯

*对比*

```

对照明设备所做的动作 对 Objective-C 对象所做的动作

开灯 生成对象

需要照明 持有对象

不需要照明 释放对象

关灯 废弃对象

```

 1.2.2 内存管理的思考方式

* 自己生成的对象,自己所持有

* 非自己生成的对象,自己也能持有

* 不再需要自己持有的对象时释放

* 非自己持有的对象无法释放

```

对象操作与 Objective-C 方法的对应

生成并持有对象 alloc/new/copy/mutablecopy 等

持有对象 retain方法

释放对象 release 方法

废弃对象 dealloc 方法

```

Cocoa 框架中的 Foundation 框架类库的 NSObject 类担负内存管理的职责。

详细了解内存管理的思考方式中出现的各个项目:

*自己生成的对象,自己持有*

自己指对象的使用环境,也可以指编程人员自身

以下名称开头的方法自己生成自己持有

* alloc(自己生成并持有对象)

* new

* copy(生成不可变更的对象)

* mutablecopy(生成可变更的对象)

*非自己生成的对象,自己也能持有*

id obj = [NSMutableArray array];

[obj retain];

非自己生成的对象通过 retain 方法可以自己持有

*不再需要自己持有的对象时释放*

* 自己生成并持有的对象,释放时使用 release

* 自己生成但不持有的对象,使用 autorelease 释放,autorelease 可以使对象在超出指定的生存范围时能够自动并正确释放

*无法释放非自己持有的对象*

释放之后无法再次释放对象,也无法访问

 alloc/retain/release/dealloc 实现

内存之区域 — NSZone

是为防止内存碎片化而引入的结构,对内存分配的区域本身进行多重化管理,根据使用对象的目的、对象的大小分配内存,从而提高了内存管理的效率。

ARC 下使用区域管理内存反而会引起内存使用效率低下以及源代码复杂化等问题

源码总结:

* 在 Objective-C 的对象中存有引用计数这一整数值

* 调用 alloc 或是 retain 方法后,引用计数值加1

* 调用 release 后,引用计数值减1

* 引用计数值为0时,调用 dealloc 方法废弃对象

1.2.3 苹果的实现

GNUstep采用将引用计数保存在对象占用内存块头部的变量中, 则是保存在引用计数表的记录。

内存块头部管理引用计数的好处:

* 少量代码即可完成

* 能够统一管理引用计数用内存块与对象用内存块

引用计数表管理引用计数的好处:

* 对象用内存块的分配无需考虑内存块头部

* 引用计数表各记录中存有内存块地址,可从各个记录追溯到各对象的内存块

1.2.5 autorelease

autorelease 就是自动释放,相当于 C 语言中的自动变量,程序执行时,若某自动变量超出其自动域,该自动变量将被自动废弃。想当于会自动调用 release 方法。

使用方法:

1. 生成并持有 NSAutoreleasePool 对象

2. 调用已分配对象的 autorelease 实例方法

3. 废弃 NSAutoreleasePool对象

NSAutoreleasePool 由程序主循环的NSRunLoop 或者在其他程序可运行的地方,对 NSAutoreleasePool 对象进行生成、持有和废弃处理。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 193,812评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,626评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,144评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,052评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 60,925评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,035评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,461评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,150评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,413评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,501评论 2 307
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,277评论 1 325
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,159评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,528评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,868评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,143评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,407评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,615评论 2 335

推荐阅读更多精彩内容