字符串使用copy修饰是为了防止在被可变字符串类型赋值后,修改可变字符串,会同时改变自身。
集合类型使用copy修饰是为了防止在被可变的集合类型赋值后,修改可变集合的内容,会同时会改变自身内容。
定义一个Person类:
@interface Person : NSObject
@property (nonatomic,strong) NSString *name;
@property (nonatomic,strong) NSArray *array;
@property (nonatomic,strong) NSDictionary *dict;
@end
首先定义一个Person类,并添加这几个属性,属性先设置为strong,然后在main函数中添加以下代码
main函数:
NSMutableString *str = [[NSMutableStringalloc] initWithString:@"aa"];
Person *p1 = [[Personalloc] init];
p1.name = str;
[str appendString:@"bb"];
NSLog(@"\n%@\n%@", str, p1.name);
NSLog(@"\n%p\n%p", str, p1.name);
运行后得到的结果:
2015-09-15 17:19:08.930 DeepCopy[3837:1317274]
aabb
aabb
2015-09-15 17:19:08.931 DeepCopy[3837:1317274]
0x10020a690
0x10020a690
从这我们可以看出两个字符串的地址是一样的,只要操作其中一个,另一个的值就会发生改变。下面我们将Person.h中的strong改成copy,再运行一下:
@property (nonatomic, copy) NSString *name;
@property (nonatomic, copy) NSArray *array;
@property (nonatomic, copy) NSDictionary *dict;
运行结果:
2015-09-15 17:05:30.314 DeepCopy[3798:1234635]
aabb
aa
2015-09-15 17:05:30.315 DeepCopy[3798:1234635]
0x10030a690
0x616125
从这可以看出使用copy时,再给p1.name赋值的时候,p1.name的地址已经不一样了,这样就可以各自修改各自的值,互不影响。NSArray和NSDictionary也是一样的。以下是其他两个类型测试代码,结果跟NSString是一样的,都是retain的时候打印出一个地址,copy则是复制了一份。
// NSArray copy, strong
// NSMutableArray *arr1 = [[NSMutableArray alloc] initWithArray:@[@"aa", @"bb"]];
// Person *p1 = [[Person alloc] init];
// p1.array = arr1;
// [arr1 addObject:@"cc"];
// NSLog(@"\n%@\n%@", arr1, p1.array);
// NSLog(@"\n%p\n%p", arr1, p1.array);
// NSDictionary copy, strong
// NSMutableDictionary *dict = [[NSMutableDictionary alloc] initWithDictionary:@{@"a": @"1"}];
// Person *p1 = [[Person alloc] init];
// p1.dict = dict;
// dict[@"b"] = @"2";
// NSLog(@"\n%@\n%@", dict, p1.dict);
// NSLog(@"\n%p\n%p", dict, p1.dict);