iOS内存管理思考方式和所有权修饰符

1、内存管理的思考方式

  引用计数式内存管理的思考方式就是思考ARC所引起的变化。

  ● 自己生成的对象,自己所持有
  ● 非自己生成的对象,自己也能持有
  ● 自己持有的对象不再需要时释放
  ● 非自己持有的对象无法释放

2、所有权修饰符

  OC编程中为了处理对象,可将变量类型定义为id类型或各种对象类型。
  所谓对象类型就是指向NSObject这样的OC类指针,例如"NSObject *",id类型用于隐藏对象类型的类名部分,相当于C语言中常用的 "void *"。
  ARC有效时,id类型和对象类型同C语言其他类型不同,其他类型上必须附加所有权修饰符。所有权修饰符一共有4种。

  ● __strong 修饰
  ● __weak 修饰
  ● __unsafe_unretained 修饰
  ● __autoreleasing 修饰符

__strong 修饰符

   __strong 修饰符是id类型和对象类型默认的所有权修饰符,也就是说,以下源码中id变量,实际上被附加了所有权修饰符。

id obj = [[NSObject alloc] init];

  id和对象类型在没有明确指定所有权修饰符时,默认为__strong 修饰符。上面的源代码和以下相同。

id __strong obj = [[NSObject alloc] init];

__weak 修饰符

  用来解决引用技术式内存管理中必然会发生的 “循环引用” 的问题。
  循环引用容易发生内存泄露。所谓内存泄漏就是应当废弃的对象在超出其生存周期后继续存在。
  循环引用的情况有多种情况,以下只举例 '自引用',当该对象持有其自身时,发生的循环引用(自引用)。

id test = [[Test alloc] init];
[test setObject:test];

  那么如何才能避免循环引用呢。使用__weak修饰符可以避免循环引用。
  __weak 修饰符与__strong 修饰符相反,提供弱引用。弱引用不能持有对象实例。

id __weak obj = [[NSObject alloc] init];

  变量obj上附加了__weak 修饰符,编译器会发出警告。因为它以自己持有的状态来保存自己生成并持有的对。象,生成的对象会立即被释放。


__weak 修饰符提示图

  所以,应该将对象赋值给附有__strong 修饰符的变量之后再赋值给__weak 修饰符的变量,就不会发生警告了。

id __strong obj0 = [[NSObject alloc] init];
id __weak obj1 = onj0;

  unsafe_unretained 修饰符和 autoreleasing 修饰符查看iOS内存管理思考方式和所有权修饰符2

你可能感兴趣的:(iOS内存管理思考方式和所有权修饰符)