黑马程序员---Objective-C autorelease

Autorelease

 

1.autorelease的基本用法

 1> 会将对象放到一个自动释放池中

 2> 当自动释放池被销毁时,会对池子里面的所有对象做一次release操作

 3> 会返回对象本身

 4> 调用完autorelease方法后,对象的计数器不变

 

2.autorelease的好处

 1> 不用再关心对象释放的时间

 2> 不用再关心什么时候调用release

 

3.autorelease的使用注意

 1> 占用内存较大的对象不要随便使用autorelease

 2> 占用内存较小的对象使用autorelease,没有太大影响

 

 

4.标准写法

 1> alloc之后调用了autorelease,又调用release

 @autoreleasepool
 {
    Person *p = [[[Person alloc] init] autorelease];
    // 错误
    [p release];
 }


 2> 连续调用多次autorelease

 @autoreleasepool
 {
    Person *p = [[[[Person alloc] init] autorelease] autorelease];
 }

5.自动释放池

 1> iOS程序运行过程中,会创建无数个池子。这些池子都是以栈结构存在(先进后出)

 2> 当一个对象调用autorelease方法时,会将这个对象放到栈顶的释放池

 

 

6.自动释放池的创建方式

 1> iOS 5.0

 NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
 [pool release]; // [pool drain];


 2> iOS 5.0 开始

 @autoreleasepool
 {
   
 }

标准写法

void test()
{
    @autoreleasepool
    {   // { 开始代表创建了释放池
        // autorelease方法会返回对象本身
        // 调用完autorelease方法后,对象的计数器不变
        // autorelease会将对象放到一个自动释放池中
        // 当自动释放池被销毁时,会对池子里面的所有对象做一次release操作
        Person *p = [[[Person alloc] init] autorelease];
        p.age = 10;
        @autoreleasepool
        {
            Person *p2 = [[[Person alloc] init] autorelease];
            p2.age = 10;
        }
        Person *p3 = [[[Person alloc] init] autorelease];
    } // } 结束代表销毁释放池
}

=============================================================

autorelease的应用

1.系统自带的方法里面没有包含allocnewcopy,说明返回的对象都是autorelease

2.开发中经常会提供一些类方法,快速创建一个已经autorelease过的对象

   1> 创建对象时不要直接用类名,一般用self

  

+ (id)person
   {
      return [[[self alloc] init] autorelease];
   }
+ (id)person
{
    return [[[self alloc] init] autorelease];
}
+ (id)personWithAge:(int)age
{
    Person *p = [self person];
    p.age = age;
    return p;
}
@autoreleasepool
    {
        Person *p = [Person personWithAge:100];   
        p2.money = 100;
    }

=============================================================

Arc的基本使用

1.ARC特点

  1> 不允许调用releaseretainretainCount

  2> 允许重写dealloc,但是不允许调用[super dealloc]

  3> @property的参数

   * strong :成员变量是强指针(适用于OC对象类型)

   * weak :成员变量是弱指针(适用于OC对象类型)

   * assign : 适用于非OC对象类型

  4> 以前的retain改为用strong

 

 指针分2种:

 1> 强指针:默认情况下,所有的指针都是强指针 __strong

 2> 弱指针:__weak

Arc中,定义弱指针是没有意义的写法

 __weak Person *p = [[Person alloc] init];

=============================================================

Arc中的循环引用 

当两端循环引用的时候,解决方案:

1> ARC

 1端用strong,另1端用weak

 @property (nonatomic, strong) Dog *dog;

2> ARC 

 1端用retain,另1端用assign

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值