一:浅copy是指针拷贝,深copy是内容拷贝
二:retain属性表示拷贝一个指针,指向同一个对象(内存地址),内容当然相同,这个对象的retain值+1.
copy属性表示生成一个全新对象,该对象retain为1,原对象没有改变,两个对象内容相同。
三:NS不可变对象,copy时执行的是浅拷贝
NSArray *array=[NSArray arrayWithObjects:@”one”,@”two”, nil];
NSMutableArray *array1=[array copy];
这里的拷贝是❤️浅拷贝,array1为NSArray类型
四:mutableCopy对于任何对象都是内容复制
五:
@property中的copy关键字
在设置NSString类型的属性的时候,我们最好设置为copy类型,这样别人使用我们定义属性的时候,他不管怎么改动该属性的赋值,都 不 会影响我们给该属性赋的值
六:
对象的自定义拷贝,必须实现NSCopying,NSMutableCopying协议,实现该协议的copyWithZone方法和mutableCopyWithZone方 法。
深拷贝和浅拷贝的区别就在于copyWithZone方法的实现。
-
(id)copyWithZone:(NSZone *)zone
{
//实现自定义浅拷贝
Person *person=[[self class] allocWithZone:zone];
person.age=_age;
person.name=_name;
return person;
}
@end -
(id)copyWithZone:(NSZone *)zone
{
//实现自定义深拷贝
Person *person=[[self class] allocWithZone:zone];
person.age=[_age copy];
person.name=[_age copy];
return person;
}
1.深拷贝是真正意义上的拷贝,是创建一个新对象。retain是指针拷贝,copy是内容拷贝。
2.浅拷贝类似retain,引用计数对象+1.创建一个指针;
retain属性表示两个对象地址相同(建立一个指针,指针拷贝),内容当然相同,这个对象的retain值+1.也就是说,
copy属性表示两个对象内容相同,新的对象retain为1,与原对象的引用计数无关,原对象没有改变。
3.代码例子:
NSArray *array=[NSArray arrayWithObjects:@“one”,@“two”, nil];
NSMutableArray *array1=[array copy];
[array1 addObject:@“three”];
//这段代码是错误的。array1,通过copy进行的是浅拷贝,即并没有真正复制array,而是也指向了array,此时array是不可变数组,无法进行新数据的添加
NSArray *array=[NSArray arrayWithObjects:@"one",@"two", nil];
NSMutableArray *array2=[array mutableCopy];
[array2 addObject:@"three"]; //这段代码是正确的,array2通过mutableCopy进行的是深拷贝,即把array真正复制了一份,并且复制后,变为了NSMutableArray ,此时array2是可变数组,可以添加数据。
@property中的copy关键字
在设置NSString类型的属性的时候,我们最好设置为copy类型,这样别人使用我们定义的属性的时候,他不管怎么改动该属性的赋值,都不会影响我们给该属性赋的值,为什么呢?
下面我们来看看
如上图所示,string2的属性是copy类型,可以看到是无法被修改的。
因为此时string2和copystring的内存地址不一样,修改一个,不会影响另外一个。
上图所示,如果string2的属性是strong类型,就可以被修改,如下图所示:
因为此时string2和copystring的内存地址都是一样的,修改一个,两个就同时被修改
copy关键字的NSMutableString崩溃
原因:
copy关键字的string的setter方法实际上是把参数copy之后再赋值给变量_string,那么此时变量_string虽然被申明为NSMutableString,但是copy之后,就把变量_string变成了不可变的NSString类型,所以就会出现方法报错,提示对不可变的NSString使用了NSMutableString的方法appendString。