• AutoReleasePool使用总结


    1.知识点

    int main(int argc, char * argv[]) {
        @autoreleasepool {
            return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class]));
        }
    }

    1.在每一个事件周期(event cycle)的开始,系统会自动创建一个自动释放池;在每一个事件周期的结尾,系统会自动销毁这个自动释放池。一般情况下可以理解为:当此APP的代码在持续运行时,自动释放池是不会被销毁的,这段时间内可以安全地使用自动释放的对象;当APP的代码运行告一段落,开始等待用户输入(或者其它事件)时,自动释放池就会被释放掉,池中的对象都会收到一个release消息,有的可能会因此被销毁。

    2.当在主线程外开启其它线程时,系统只会在主线程中自动生成并销毁掉自动释放池。

    2.例子

    1.正常情况,属性为retain的应该使用autorelease,因为set方法会自动调用retain;属性为assign的不能使用。注意,只用使用self.retainView才会调用set方法,如果使用_retainView,则直接对内存赋值,不会调用set方法。

        self.retainView = [[[UIView alloc]init]autorelease];
        self.assignView = [[UIView alloc]init];

    2.应该使用autorelease,因为在addGestureRecognizer时会自动retain。

        UITapGestureRecognizer *tapGesture = [[[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(doTap:)]autorelease];
        tapGesture.delegate = self;
        [self.maskView addGestureRecognizer:tapGesture];

    3.应该使用autorelease,因为cell要返回继续处理(返回后应该会retain),不能直接release。

        cell = [tableView dequeueReusableCellWithIdentifier:@"cell"];
        if(cell == nil){
            cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:@"cell"] autorelease];
        }
        return cell;
    

     4.类级构造方法会自动调用autorelease,比如[NSMutableArray array]。如果此array为cell的内容,则正常加载cell没问题,加载完以后会随着autoreleasepool的释放被release。因此如果再刷新cell则会出错(比如上下滚动tableView)。因此要retain一次,或者使用对象级构造方法alloc。

  • 相关阅读:
    模拟算法(八)
    迭代算法(七)
    试探法是一种委婉的做法(六)
    贪心算法并不贪婪(五)
    各个击破的分治算法(四)
    充分利用自己的递归算法(三)
    一起学Spring之Web基础篇
    C# 利用AForge进行摄像头信息采集
    一起学Spring之注解和Schema方式实现AOP
    一起学Spring之AOP
  • 原文地址:https://www.cnblogs.com/zhongriqianqian/p/3978755.html
Copyright © 2020-2023  润新知