浅拷贝就是对内存地址的复制,让目标对象指针和源对象指向同一片内存空间。如:ios
char* str = (char*)malloc(100); char* str2 = str;
浅拷贝只是对对象的简单拷贝,让几个对象共用一片内存,当内存销毁的时候,指向这片内存的几个指针须要从新定义才可使用,要否则会成为野指针。app
在 iOS 里面, 使用retain
关键字进行引用计数,就是一种更加保险的浅拷贝。他既让几个指针共用同一片内存空间,又能够在release 因为计数的存在,不会轻易的销毁内存,达到更加简单使用的目的。atom
深拷贝是指拷贝对象的具体内容,而内存地址是自主分配的,拷贝结束以后,两个对象虽然存的值是相同的,可是内存地址不同,两个对象也互不影响,互不干涉。指针
copy
与 retain
的区别:copy
是建立一个新对象,retain
是建立一个指针,引用对象计数加一。 copy
属性标识两个对象内容相同,新的对象retain count为1, 与旧有对象引用计数无关,旧有对象没有变化。copy
减小对象对上下文的依赖。code
iOS提供了copy
和mutableCopy
方法,顾名思义,copy
就是复制了一个imutable的对象,而mutableCopy
就是复制了一个mutable的对象。如下将举几个例子来讲明。
这里指的是NSString
, NSNumber
等等一类的对象。对象
NSString *string = @”dddd"; NSString *stringCopy = [string copy]; NSMutableString *stringDCopy = [string mutableCopy]; [stringMCopy appendString:@"!!"];
查看内存能够发现,string
和stringCopy
指向的是同一块内存区域(weak reference),引用计数没有发生改变。而stringMCopy
则是咱们所说的真正意义上的复制,系统为其分配了新内存,是两个独立的字符串内容是同样的。内存
固然在 ios 中并非全部的对象都支持copy
,mutableCopy
,遵照NSCopying
协议的类能够发送copy
消息,遵照NSMutableCopying
协议的类才能够发送mutableCopy
消息。字符串
假如发送了一个没有遵照上诉两协议而发送copy
或者 mutableCopy
,那么就会发生异常。可是默认的ios类并无遵照这两个协议。若是想自定义一下copy
那么就必须遵照NSCopying
,而且实现 copyWithZone:
方法,若是想自定义一下mutableCopy
那么就必须遵照NSMutableCopying
,而且实现 mutableCopyWithZone:
方法。string
若是是咱们定义的对象,那么咱们本身要实现NSCopying
, NSMutableCopying
这样就能调用copy
和mutablecopy
了。举个例子:it
@interface MyObj : NSObject<NSCopying, NSMutableCopying>{ NSMutableString *_name; NSString * _imutableStr ; int _age; } @property (nonatomic, retain) NSMutableString *name; @property (nonatomic, retain) NSString *imutableStr; @property (nonatomic) int age;
拷贝构造:
(id)copyWithZone:(NSZone *)zone{ MyObj *copy = [[[self class] allocWithZone :zone] init]; copy->name = [_name copy]; copy->imutableStr = [_imutableStr copy]; copy->age = age; return copy; }
拷贝构造:
- (id)mutableCopyWithZone:(NSZone *)zone{ MyObj *copy = NSCopyObject(self, 0, zone); copy->name = [_name mutableCopy]; copy->age = age; return copy; }