深拷贝、浅拷贝

一:浅copy是指针拷贝,深copy是内容拷贝

二:retain属性表示拷贝一个指针,指向同一个对象(内存地址),内容当然相同,这个对象的retain值+1.
copy属性表示生成一个全新对象,该对象retain为1,原对象没有改变,两个对象内容相同。

三:NS不可变对象,copy时执行的是浅拷贝
NSArray *array=[NSArray arrayWithObjects:@”one”,@”two”, nil];
NSMutableArray *array1=[array copy];
这里的拷贝是❤️浅拷贝,array1为NSArray类型

四:mutableCopy对于任何对象都是内容复制

五:
@property中的copy关键字
在设置NSString类型的属性的时候,我们最好设置为copy类型,这样别人使用我们定义属性的时候,他不管怎么改动该属性的赋值,都 不 会影响我们给该属性赋的值

六:
对象的自定义拷贝,必须实现NSCopying,NSMutableCopying协议,实现该协议的copyWithZone方法和mutableCopyWithZone方 法。
深拷贝和浅拷贝的区别就在于copyWithZone方法的实现。

  • (id)copyWithZone:(NSZone *)zone
    {
    //实现自定义浅拷贝
    Person *person=[[self class] allocWithZone:zone];
    person.age=_age;
    person.name=_name;
    return person;
    }
    @end

  • (id)copyWithZone:(NSZone *)zone
    {
    //实现自定义深拷贝
    Person *person=[[self class] allocWithZone:zone];
    person.age=[_age copy];
    person.name=[_age copy];
    return person;
    }

1.深拷贝是真正意义上的拷贝,是创建一个新对象。retain是指针拷贝,copy是内容拷贝。
2.浅拷贝类似retain,引用计数对象+1.创建一个指针;
retain属性表示两个对象地址相同(建立一个指针,指针拷贝),内容当然相同,这个对象的retain值+1.也就是说,
copy属性表示两个对象内容相同,新的对象retain为1,与原对象的引用计数无关,原对象没有改变。
3.代码例子:
NSArray *array=[NSArray arrayWithObjects:@“one”,@“two”, nil];
NSMutableArray *array1=[array copy];
[array1 addObject:@“three”];
//这段代码是错误的。array1,通过copy进行的是浅拷贝,即并没有真正复制array,而是也指向了array,此时array是不可变数组,无法进行新数据的添加

 NSArray *array=[NSArray arrayWithObjects:@"one",@"two", nil];       
 NSMutableArray *array2=[array mutableCopy];        
 [array2 addObject:@"three"];  //这段代码是正确的,array2通过mutableCopy进行的是深拷贝,即把array真正复制了一份,并且复制后,变为了NSMutableArray ,此时array2是可变数组,可以添加数据。

@property中的copy关键字

在设置NSString类型的属性的时候,我们最好设置为copy类型,这样别人使用我们定义的属性的时候,他不管怎么改动该属性的赋值,都不会影响我们给该属性赋的值,为什么呢?

下面我们来看看

1470132996440615.png

如上图所示,string2的属性是copy类型,可以看到是无法被修改的。

因为此时string2和copystring的内存地址不一样,修改一个,不会影响另外一个。

1470133013241729.png

上图所示,如果string2的属性是strong类型,就可以被修改,如下图所示:

因为此时string2和copystring的内存地址都是一样的,修改一个,两个就同时被修改

copy关键字的NSMutableString崩溃

1470133027285088.png

原因:

copy关键字的string的setter方法实际上是把参数copy之后再赋值给变量_string,那么此时变量_string虽然被申明为NSMutableString,但是copy之后,就把变量_string变成了不可变的NSString类型,所以就会出现方法报错,提示对不可变的NSString使用了NSMutableString的方法appendString。

### 深拷贝浅拷贝的概念 在 Python 中,深拷贝浅拷贝用于处理数据结构的复制操作。浅拷贝仅创建对象的新引用,而不实际复制内部的对象内容;而深拷贝则会递归地复制整个对象及其嵌套的内容。 #### 浅拷贝的特点 当执行浅拷贝时,新对象会被创建,但对于可变类型的元素(如列表或字典),其内部的子对象不会被真正复制,而是共享相同的内存位置[^2]。这意味着修改原始对象中的某些部分可能会影响副本。 #### 深拷贝的特点 相比之下,深拷贝不仅复制顶层容器本身,还会递归地复制所有的子对象到新的存储空间中[^1]。因此,在任何层次上更改原对象都不会影响它的深层副本。 ### 实现方法对比 以下是两种不同方式的具体实现: #### 使用 `copy` 模块进行浅拷贝 ```python import copy original_list = [[1, 2], [3, 4]] shallow_copied_list = copy.copy(original_list) print(shallow_copied_list is original_list) # False (不同的顶级列表实例) print(shallow_copied_list[0] is original_list[0]) # True (相同的第一层子项) ``` 上述例子展示了通过调用 `copy.copy()` 函数来完成一次浅拷贝的过程。 #### 利用 `deepcopy` 方法达成完全独立的复制品 对于更复杂的场景,则需借助于 `copy.deepcopy()` 来获得真正的分离版本: ```python import copy original_dict = {"key": [1, 2]} deep_copied_dict = copy.deepcopy(original_dict) print(deep_copied_dict["key"] is original_dict["key"]) # False (各自拥有独立数组) ``` 这里可以看出即使是在多级嵌套情况下也能保持彼此间的隔离状态。 ### 总结说明 综上所述,选择合适的策略取决于具体需求——如果只需要简单表面级别的保护即可满足应用逻辑的话那么采用轻量化的浅拷贝就足够了; 反之亦然需要考虑性能开销的同时兼顾安全性的时候就应该倾向运用耗资源更多的深度克隆技术.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值