autorelease和autoreleasepool 注意事项优缺点

1. 在使用Dispatch Queue时, 虽然其Pool中每个thread都会有autoreleasepool,但是如果我们给的task每个都创建一些对象,并做autorelease,那若提交的task太多,比如有100000个,那在thread退出前,这些内存都无法释放,等于说有大量内存被占用而释放不了,也类似于leak了,所以这时,最好每个提交的task都有自己的autoreleasepool,task完成了,对象也释放了,下次再用,再分配,再释放。

2. 跟1类似的,如果没有函数内部有loop,并且每个loop都创建很多对象,如果希望这些对象早点释放,就可以自己创建autoreleasepool

1.autorelease 基本用法

  • 对象执行autorelease方法时会将对象添加到自动释放池中
  • 当自动释放池销毁时自动释放池中所有对象作release操作
  • 对象执行autorelease方法后自身引用计数器不会改变,而且会返回对象本身

2.autorelease 的优点

  • autorelease实际上只是把对release的调用延迟了,对于每一次autorelease系统只是把该对象放入了当前的autorelease pool中,当该pool被释放时,该pool中的所有对象会被调用Release
  • 因为只有在自动释放池销毁的时候它里面的对象才销毁,因此不用关心对象销毁的时间也就不用关心什么时候调用release

3.autorelease 使用注意

  • 操作占用内存比较大的对象的时候不要随便使用,担心对象释放的时间太迟
  • 操作占用内存比较小的对象可以使用

4.atureleasepool自动释放池

自动释放池存储于内存中的栈中遵循"先进后出"原则

 
 
  1. #import <Foundation/Foundation.h> 
  2. #import "Person.h" 
  3. int main(int argc, const char * argv[]) 
  4.      
  5.     // 自动释放池1 
  6.     @autoreleasepool { 
  7.          
  8.  // 对象的释放交给 自动释放池去管理 不用再写[person release] 
  9.         Person *person = [[[Person alloc] init] autorelease];  
  10.          
  11.         // 再创建一个自动释放池2 
  12.         @autoreleasepool { 
  13.              
  14.             Person *person2 = [[[Person alloc] init] autorelease]; 
  15.         } 
  16.         
  17.         Person *person3 = [[[Person alloc] init] autorelease];    
  18.     } 
  19.     return 0; 

从上面的代码可以看出:执行代码时首先是person2对象先被销毁,然后是外面的对象person和perons3 内存中的表现如下:

5.使用常见错误

 
 
  1. // 销毁自动释放池的时候 要对person再执行release操作的话 会报野指针错误 
  2.     @autoreleasepool { 
  3.         Person *person = [[[Person alloc] init] autorelease]; 
  4.         [person release]; 
  5.     }
 
 
  1. // 对象执行两次autorelease意味着自动释放池销毁的时候 对象会执行两次release操作 会报野指针错误 
  2.     @autoreleasepool { 
  3.         Person *person = [[[[Person alloc] init] autorelease] autorelease]; 
  4.     } 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值