iOS 里面的浅拷贝:

在 iOS 里面, 使用retain 关键字进行引用计数,就是一种更加保险的浅拷贝。他既让几个指针共用同一片内存空间,又可以在release 由于计数的存在,不会轻易的销毁内存,达到更加简单使用的目的。

iOS里的深拷贝:

iOS提供了copy和mutableCopy方法,顾名思义,copy就是复制了一个imutable的对象,而mutableCopy就是复制了一个mutable的对象。以下将举几个例子来说明。
这里指的是NSString, NSNumber等等一类的对象。

查看内存可以发现,string和stringCopy指向的是同一块内存区域(weak reference),引用计数没有发生改变。而stringMCopy则是我们所说的真正意义上的复制,系统为其分配了新内存,是两个独立的字符串内容是一样的。

拷贝构造:

当然在 ios 中并不是所有的对象都支持copy,mutableCopy,遵守NSCopying协议的类可以发送copy消息,遵守NSMutableCopying协议的类才可以发送mutableCopy消息。

假如发送了一个没有遵守上诉两协议而发送copy或者 mutableCopy,那么就会发生异常。但是默认的ios类并没有遵守这两个协议。如果想自定义一下copy 那么就必须遵守NSCopying,并且实现 copyWithZone: 方法,如果想自定义一下mutableCopy 那么就必须遵守NSMutableCopying,并且实现 mutableCopyWithZone: 方法。

如果是我们定义的对象,那么我们自己要实现NSCopying , NSMutableCopying这样就能调用copy和mutablecopy了。举个例子:


@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;
copy拷贝构造:

- (id)copyWithZone:(NSZone *)zone{
     MyObj *copy = [[[self class] allocWithZone :zone] init];
     copy->name = [_name copy];
     copy->imutableStr = [_imutableStr copy];
     copy->age = age;
     return  copy;
}

mutableCopy拷贝构造:
- (id)mutableCopyWithZone:(NSZone *)zone{
     MyObj *copy = NSCopyObject(self, 0, zone);
     copy->name = [_name mutableCopy];
     copy->age = age;
     return  copy;
}

简述值传递和引用传递的区别



所谓的值传递吗, 就是说仅将对象的值传递给目标对象, 就是相当于copy; 



系统将为目标对象重新开辟一个完全相同的内存空间, 


所谓的引用传递就是说将对象在内存中的地址传递给目标对象, 就是原对象与目标对象使用的时同一块的内存储存空间,



此时, 如果目标对象的进行修改的时候内存中的数据也会改变,