IOS 内存管理 经典.pptVIP

  1. 1、本文档共9页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
IOS 内存管理 经典

IOS 内存管理介绍 Objective-C对象生成与释放 1、Objective-C的对象生成于堆之上,生成之后,需要一个指针来指向它。 ClassA *obj1 = [[ClassA alloc] init]; 2、 Objective-C的对象在使用完成之后不会自动销毁,需要执行dealloc来释放空间(销毁),否则内存泄露。 [obj1 dealloc]; 下面代码中obj2是否需要调用dealloc? ClassA *obj1 = [[ClassA alloc] init]; ClassA *obj2 = obj1; [obj1 hello]; //输出hello [obj1 dealloc]; [obj2 hello]; //能够执行这一行和下一行吗? [obj2 dealloc]; IOS内存管理机制 iphone的内存管理方法采用“保留计数”(retain count)机制, 当一个对象被创建时,保留计数为1;每增加一个所有者则对象的保留计数增加1;同时,当对象被release,保留计数减1,失去一个所有者。当保留计数为0时,对象被销毁。 引用计数的主要接口 1,alloc, allocWithZone,new(带初始化) 为对象分配内存,retainCount为“1”,并返回此实例 2,retain retainCount 加“1” 3,copy,mutableCopy 复制一个实例,retainCount数为“1”,返回此实例。所得到的对象是与其它上下文无关的,独立的对象(干净对象)。 4,release retainCount 减“1”,减到“0”时调用此对象的dealloc方法 5,autorelease 在当前上下文的AutoreleasePool栈顶的autoreleasePool实例添加此对象,由于它的引入使Objective-C(非GC管理环境)由全手动内存管理上升到半自动化。 Objective-C内存管理准则 我们可以把上面的接口按对retainCount的操作性质归为两类, A类是加一操作:1,2,3 B类是减一操作:4,5(延时释放) 内存管理准则如下: 1,A与B类的调用次数保持一制 2,为了很好的保障准则一,以实例对象为单位,谁A了就谁B,没有第二者参与 例如: NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init]; NSObject *o = [[NSObject alloc] init]; //retainCount为1 [o retain]; //retainCount为2 [o release]; //retainCount为1 [o autorelease]; //retainCount为1 [pool release]; //retaincount为0,触发dealloc方法 赋值retain count不会增加,注意内存泄漏 ClassA *obj1 = [[ClassA alloc] init]; //retain count = 1 ClassA *obj2 = obj1; //retain count = 1 [obj2 retain]; //retain count = 2 [obj1 hello]; //输出hello [obj1 release]; //retain count = 2 – 1 = 1 [obj2 hello]; //输出hello [obj2 release]; //retain count = 0,对象被销毁 问题解决!注意,如果没有调用[obj2 release],这个对象的retain count始终为1,不会被销毁,内存泄露。 autorelease pool原理分析 1、autorelease pool不是天生的,需要手动创立。只不过在新建一个iphone项目时,xcode会自动帮你写好。autorelease pool的真名是NSAutoreleasePool。 2、NSAutoreleasePool内部包含一个数组(NSMutableArray),用来保存声明为autorelease的所有对象。如果一个对象声明为autorelease,系统所做的工作就是把这个对象加入到这个数组中去。ClassA *obj1 = [[[ClassA alloc] init] autorelease]; //retain count = 1,把此对象加入autorelease pool中 3、 NSAutoreleasePool自身在销毁的时候,会遍历一遍这个数组,r

文档评论(0)

zijingling + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档