首页 > 其他 > 详细

Objective -C 之copy(复制)

时间:2015-11-03 00:41:47      阅读:180      评论:0      收藏:0      [点我收藏+]

在这里首先提及的就是定义属性是用的属性列表中的copy

@property(nonatomic,copy)NSString *name;

在这里我定义了一个Person类,此处不再陈述

下面是代码

        Person *p = [[Person alloc] init];

        NSMutableString *s = [[NSMutableString alloc] initWithFormat:@"123"];     

        p.name = s;   //此时,name的值为@"123"

        NSLog(@"**%@",p.name);

        [s appendString:@"world"];

        NSLog(@"%@",p.name);

        NSLog(@"%p---%p",s,p.name);

输出结果:

**123

123

0x100206e00---0x100206cf0

可以看出可变字符串的值赋给了属性name,但是地址变化了,在第一次输出123后边我又对s进行了重新赋值为world,但是并未影响到p.name的值,这也就验证了地址确实不同了。其实它内部是通过

- (void)setName:(NSMutableString *)name

{

 if(_name != name){          //判断是否需要重新赋值

      [_name release];        //释放旧引用,计数器-1

      _name = [name copy];   //重新赋值,使用copy********就是这里*********

   }

}

进行了深复制。因为s是可变数组,所以copy之后会开辟一个新的地址空间。假如s是不可变数组,那么就会进行浅复制

假如把代码改成:

        Person *p = [[Person alloc] init];

        NSString *s = @"123";     

        p.name = s;   //此时,name的值为@"123"

        NSLog(@"%@",p.name);

        NSLog(@"%p---%p",s,p.name);

输出结果:

123

0x100001068---0x100001068

地址是一样的,说明进行了浅复制

总结:

copy:浅拷贝:不产生新的对象,直接指向原有对象(地址数据相同,虽然指针的名字不同)
    拷贝出的结果是不可变对象,跟其接受类型没有关系,跟其传入类型也没有关系
mutableCopy:深拷贝:产生新的对象,其内容是原有对象的内容,地址变了
    拷贝的结果是可变对象,跟其传入的类型没有关系,但是会受其接收类型的影响
copy:被复制着是可变,则为深,否则为浅

NSString *s2 = [s1 copy];//八种情况中(s1:mutableString/String;s2:mutableString/String;copy/mutableCopy),只有s1为不可变和利用copy方法  同时满足时为浅复制,其余为深复制 

//当使用NSCopy复制一个不可变对象时,其行为是浅复制,其余情况都是深拷贝
//当使用NSMutablecopy时,是深拷贝

那么为什么浅复制地址不变呢?

        当被copy者类型是字符串常量时(就是不可变字符串),系统会为我们优化,声明了多个字符串,
        但是都是常量,且内容相等,那么系统就只为我们申请一块空间。
赋值过程:输入数据→寄存器处理→开辟内存→写入数据。一次深复制,可以得到被复制对象指针,并进行一次赋值操作。

Objective -C 之copy(复制)

原文:http://www.cnblogs.com/liuguan/p/4931933.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!