• 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]; // 错误写法, 过度释放
     }
  • 相关阅读:
    游戏开发挑战中心规划(16)
    游戏开发关卡设计(16)
    借鉴来的面试经验
    Scrapy:学习笔记(2)——Scrapy项目
    Scrapy:学习笔记(1)——XPath
    Django:学习笔记(8)——文件上传
    And Design:拓荒笔记——Form表单
    React:快速上手(7)——使用中间件实现异步操作
    JavaScript:学习笔记(9)——Promise对象
    JavaScript:学习笔记(8)——对象扩展运算符
  • 原文地址:https://www.cnblogs.com/xufengyuan/p/6590177.html
Copyright © 2020-2023  润新知