zoukankan      html  css  js  c++  java
  • autorelease注意事项

    1.autorelease使用注意

    • 并不是放到自动释放池代码中,都会自动加入到自动释放池
     @autoreleasepool {
        // 因为没有调用 autorelease 方法,所以对象没有加入到自动释放池
        Person *p = [[Person alloc] init];
        [p run];
    }
    • 在自动释放池的外部发送autorelease 不会被加入到自动释放池中
    1. autorelease是一个方法,只有在自动释 放池中调用才有效。
     @autoreleasepool {
     }
     // 没有与之对应的自动释放池, 只有在自动释放池中调用autorelease才会放到释放池
     Person *p = [[[Person alloc] init] autorelease];
     [p run];
    
     // 正确写法
      @autoreleasepool {
        Person *p = [[[Person alloc] init] autorelease];
     }
    
     // 正确写法
     Person *p = [[Person alloc] init];
      @autoreleasepool {
        [p autorelease];
     }
    • 自动释放池的嵌套使用
    1. 自动释放池是以栈的形式存在
    2. 由于栈只有一个入口, 所以调用autorelease会将对象放到栈顶的自动释放池
    3. 栈顶就是离调用autorelease方法最近的自动释放池
    @autoreleasepool { // 栈底自动释放池
      @autoreleasepool {
          @autoreleasepool { // 栈顶自动释放池
              Person *p = [[[Person alloc] init] autorelease];
          }
          Person *p = [[[Person alloc] init] autorelease];
      }
    }
    • 自动释放池中不适宜放占用内存比较大的对象
    1. 尽量避免对大内存使用该方法,对于这种延迟释放机制,还是尽量少用
    2. 不要把大量循环操作放到同一个 @autoreleasepool 之间,这样会造成内存峰值的上升
    // 内存暴涨
        @autoreleasepool {
            for (int i = 0; i < 99999; ++i) {
                Person *p = [[[Person alloc] init] autorelease];
            }
        }
    // 内存不会暴涨
     for (int i = 0; i < 99999; ++i) {
            @autoreleasepool {
                Person *p = [[[Person alloc] init] autorelease];
            }
        }

    2.autorelease错误用法

    • 不要连续调用autorelease
     @autoreleasepool {
     // 错误写法, 过度释放
        Person *p = [[[[Person alloc] init] autorelease] autorelease];
     }
    • 调用autorelease后又调用release
     @autoreleasepool {
        Person *p = [[[Person alloc] init] autorelease];
        [p release]; // 错误写法, 过度释放
     }
  • 相关阅读:
    Linux下MySQL数据库常用基本操作 一
    Cdnbes负载均衡的权重用法解释
    docker安装
    centos网卡配置和防火墙停止和启动
    Excel 如何锁定表头
    权值线段树 基础入门知识详解
    JZOJ 3362. 【NOI2013模拟】数数(DFS)
    JZOJ 3348. 【NOI2013模拟】秘密任务(最短路+最小割唯一性)
    JZOJ 3303. 【集训队互测2013】城市规划(卷积+分治NTT)
    FFT快速傅里叶变换(超详细的入门学习总结)
  • 原文地址:https://www.cnblogs.com/xufengyuan/p/6590177.html
Copyright © 2011-2022 走看看