iOS笔记-copy

copy和strong在@property中的使用

我们来看一下以下两段代码:
第一段

@interface JWUser : NSObject<NSCopying>

@property (nonatomic, readwrite, strong) NSArray *array;

@end

JWUser *user = [[JWUser alloc] init];   
NSMutableArray *mutableArray = [[NSMutableArray alloc] initWithArray:@[ @1, @2, @3, @4 ]];
user.array = mutableArray;
[mutableArray removeAllObjects];;
NSLog(@"%@",user.array);

第二段

@interface JWUser : NSObject<NSCopying>

@property (nonatomic, readwrite, copy) NSArray *array;

@end

JWUser *user = [[JWUser alloc] init];
NSMutableArray *mutableArray = [[NSMutableArray alloc] initWithArray:@[ @1, @2, @3, @4 ]];
user.array = mutableArray;
[mutableArray removeAllObjects];
NSLog(@"%@",user.array);

输出结果:

第一段使用stroy的输出结果
2017-05-11 14:17:02.854 RuntimeTest[12080:2551256] (
)

第二段使用copy的输出结果
2017-05-11 14:21:18.811 RuntimeTest[12132:2561145] (
    1,
    2,
    3,
    4
)

上述代码的差异就是array这个属性被定义时使用了不同的内存管理语义strong和copy:

  1. 父类的指针是可以子类对象,也就是说NSArray类型的对象是可以指向NSMutableArray类型的对象的。因为strong的特性只是强持有对象,也就是引用计算+1,实际都是指向的同一块内存地址。所以上述代码中将mutableArray这个数值直接赋值给array时,array对应的指针指向的地址其实就是一块可变数值内存,所以指向[mutableArray removeAllObjects];时,array的数组也会被清空;

  2. 如果使用的是copy,因为copy本身的特性就是为了保护对象属性不受外界影响,不论传入的对象是否可变最终,对象属性始终会指向一块不可变内存。所以上述第二段代码输出的结果不会随着mutableArray的改变而改变。

我们再来看一段代码:

NSMutableArray *mutableArray = [[NSMutableArray alloc] initWithArray:@[ @1, @2, @3, @4 ]];
NSMutableArray *copyArray = [mutableArray copy];
[copyArray removeAllObjects];

运行结果是闪退

reason: '-[__NSArrayI removeAllObjects]: unrecognized selector sent to instance 0x608000051520'

从报错信息可以看成,编译器认为我们对NSArray数组执行了removeAllObjects这个NSMutableArray才有的方法。

原因很简单,上面第二条有说过,copy之后对象都是不可变对象,上述代码中NSMutableArray *copyArray = [mutableArray copy];的结果就是copyArray指向了一块不可变内存,所以闪退。

copy的深拷贝和浅拷贝

深拷贝就是内容拷贝,这种拷贝会将内容复制到一快新的内存中;
浅拷贝就是指针拷贝,

传入不同对象的copy和mutableCopy

  1. 对非集合类对象的copy和mutableCopy
  • 在非集合类中的:对immutable对象进行copy操作,是指针复制,mutableCopy操作是内容复制;
  • 对mutable对象进行copy和mutableCopy都是内容复制;
  1. 对集合类对象的copy和mutableCopy
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,313评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,369评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,916评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,333评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,425评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,481评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,491评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,268评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,719评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,004评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,179评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,832评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,510评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,153评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,402评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,045评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,071评论 2 352

推荐阅读更多精彩内容