简单的来说就是,在有指针的情况下,
浅拷贝只是增加了一个指针指向已经存在的内存;
深拷贝就是增加一个指针并且申请一个新的内存,使这个增加的指针指向这个新的内存。采用深拷贝的情况下,释放内存的时候就不会出现在浅拷贝时重复释放同一内存的错误。
阅读本文之前首先了解copy与retain的区别
copy与retain的区别:
copy是创建一个新对象,retain是创建一个指针,引用对象计数加1。copy属性表示两个对象内容相同,新的对象retain为1 ,与旧有对象的引用计数无关,旧有对象没有变化。copy减少对象对上下文的依赖。
retain属性表示两个对象地址相同(建立一个指针,指针拷贝),内容当然相同,这个对象的retain值+1也就是说,
retain 是指针拷贝,copy 是内容拷贝。
当然在iOS中并不是所有的对象都支持copy,mutableCopy,遵守NSCopying 协议的类可以发送copy消息,遵守NSMutableCopying 协议的类才可以发送mutableCopy消息。
假如发送了一个没有遵守上诉两协议而发送 copy或者 mutableCopy,那么就会发生异常。
但是默认的iOS类并没有遵守这两个协议。
如果想自定义一下copy 那么就必须遵守NSCopying,并且实现 copyWithZone: 方法;
如果想自定义一下mutableCopy 那么就必须遵守NSMutableCopying,并且实现 mutableCopyWithZone: 方法。
1. 系统的非容器类对象
这里指的是NSString,NSNumber等等一类的对象。
NSString *string = @"origion";
NSString *stringCopy = [string copy];
NSMutableString *stringMCopy = [string mutableCopy];
[stringMCopy appendString:@"!!"];
查看内存可以发现,string和stringCopy指向的是同一块内存区域(又叫弱引用weak reference),此时str