数组的strong copy理解

 

一、数组的不同情况下的copy,mutablecopy分析

  1.不可变数组的copy(没有创建新对象,复制的只是指针)
 
 
 
  2.不可变数组的mutable copy(创建新对象)
 
 
  3.可变数组的copy(创建新对象)
 
 
  4.可变数组的mutable copy(创建新对象)
 
 
 

 二、“=”运算符

  “=”的作用(“=” 运算符只是让左边的指针指向右边指针指向的内存区域,如果需要左边的指针指向新的内存区,必须要在右边进行新对象的创建,即在“=”右边使用copy,mutablecopy,new等来创建新对象)

 

三、修饰符strong,copy

  strong修饰的属性赋值时对“=”右边的property先release再retain,引用计数加一而已;

  copy修饰符对“=”右边的property先release再copy

 
由于遵循上面的原理,看看我对代码的理解:
//cMArr 是由copy修饰的,所以在赋值时其实是把[mmArr mutableCopy] 执行copy之后的结果赋值给了cMArr,这时结果其实是一个NSArray类型(可变数组copy之后生成新对象,新对象为不可变数组)
//sMArr 是由strong修饰,赋值时相当于是对右边的对象先release再retain,直接引用计数加一,并没有创造新的对象,所以sMArr 和mmArr指向同一内存区
 
@property(copy,nonatomic) NSMutableArray *cMArr;
@property(strong,nonatomic) NSMutableArray *sMArr;
 
NSMutableArray *mmArr = [@[@"111",@"222"] mutableCopy];
    self.cMArr = [mmArr mutableCopy];
    self.sMArr = mmArr;
    NSLog(@"\nmmArr = %p %@, \ncmArr = %p %@,\nsmArr = %p %@",mmArr,[mmArr class],self.cMArr,[self.cMArr class],self.sMArr,[self.sMArr class]);
打印结果:
 
 
 
用法总结:

   1》copy修饰不可变类型,这样赋值的时候每次都要对右边的对象copy一次,确保内容的独立性。

    2》strong修饰可变类型,赋值时直接对等号右边进行引用计数加一,当然等号右边要是不可变类型,代码mutablecopy之后再赋值。
    3》strong修饰不可变类型,如果等号右边是可变类型会出现赋值之后等号左边内容是可变类型的情况,当然可以赋值前代码copy一下避免这个问题(慎用,谨防忘记代码copy然后才能赋值)
    4》copy修饰可变类型,每次赋值都对等号右边进行一次copy,最终结果只能是不可变类型(禁用)

 

 

 
其实本文记录的只是深复制和浅复制的一个特例而已,搞懂了深复制和浅复制,无论是数组还是字典亦或是字符串都会很通透的。
我的另一篇关于深复制和浅复制的文章和本文应该也是殊途同归

 

前四张图片借用文档:http://blog.csdn.net/frankisbaby/article/details/54946115

 
 
posted @ 2017-06-01 10:21  有棱角的圆  阅读(723)  评论(0编辑  收藏  举报