答:
1)、copy修饰的属性进行赋值的时候会生成一份不可变的副本,此时修改副本array(增删之类的操作)会提示找不到方法而报异常;
2)、不写原子性修饰词默认使用atomic,而atomic性能比nonatomic差很多。
扩展:
浅拷贝:指针拷贝,不生成新对象
- 不可变对象的不可变拷贝
NSArray *array = [NSArray array];
//相同地址
NSLog(@"%p",array);
NSLog(@"%p",[array copy]);
// __NSArray0 (不可变数组)
NSLog(@"%@",NSStringFromClass([[array copy] class]));
输出:

深拷贝:生成一个新对象,对象内容相同( 除浅拷贝那种情况,其他都是深拷贝)
- 可变对象的可变拷贝
NSMutableArray *mutArray = [NSMutableArray array];
//输出不同地址
NSLog(@"%p",mutArray);
NSLog(@"%p",[mutArray mutableCopy]);
// __NSArrayM (可变数组)
NSLog(@"%@",NSStringFromClass([[mutArray mutableCopy] class]));
输出:

- 可变对象的不可变拷贝
NSMutableArray *mutArray = [NSMutableArray array];
//不同地址
NSLog(@"%p",mutArray);
NSLog(@"%p",[mutArray copy]);
// __NSArray0
NSLog(@"%@",NSStringFromClass([[mutArray copy] class]));
输出:

- 不可变对象的可变拷贝
NSArray *array = [NSArray array];
//不同对象
NSLog(@"%p",array);
NSLog(@"%p",[array mutableCopy]);
// __NSArrayM
NSLog(@"%@",NSStringFromClass([[array mutableCopy] class]));
输出:

总结:
除不可变对象的不可变拷贝为浅拷贝,其余都是深拷贝

本文详细解释了深拷贝和浅拷贝的概念,通过对比不同类型的数组拷贝(如NSArray和NSMutableArray),阐述了拷贝过程中的地址变化和对象类型转换,帮助理解iOS开发中对象拷贝的机制。
2952

被折叠的 条评论
为什么被折叠?



