集合数据类型的拷贝

浅拷贝 Shallow Copies

目前有许多方法来实现浅拷贝, 当你尝试一次浅拷贝时,集合中的对象会被 retain 一次, 并且新的集合会引用集合中对象的指针
示例 1

NSArray *shallowCopyArray = [someArray copyWithZone:nil];
NSDictionary *shallowCopyDict = [[NSDictionary alloc] initWithDictionary:someDictionary copyItems:NO];

深拷贝 Deep Copies

有两种方法对一个集合进行深拷贝, 可以使用 initWithArray:copyItems: 第二个参数为 YES, 集合中的每个对象都会执行一次 copyWithZone: 方法, 如果对象有适配 NSCopying 协议, 对象就会被深拷贝到新的集合中, 新的集合会是新生成对象的唯一持有者, 但是如果对象没有适配 NSCopying 协议, 就会产生 Runtime Error. 然而,
copyWithZone: 是一次浅拷贝, 这种类型的拷贝仅可有能产生一次 one-level-deep 拷贝, 可以类似 示例 2 那样显示的调用
示例 2

NSArray *deepCopyArray=[[NSArray alloc] initWithArray:someArray copyItems:YES];

这项技术可以其他的集合类型也适用, 如果你需要一个真正的深拷贝的话, 例如你的 array 中的 item 也包含其他 array, 你就需要保证你内部所有的 item 都实现了 NSCoding 协议, 参考示例 3
示例 3

NSArray* trueDeepCopyArray = [NSKeyedUnarchiver unarchiveObjectWithData:
          [NSKeyedArchiver archivedDataWithRootObject:oldArray]];

再来谈谈 copyWithZone:mutableCopyWithZone: zone 参数是可以为 NULL 的, 如果 zoneNULL 则会使用默认的 zone, 来之 NSDefaultMallocZone()

  • copyWithZone:,会返回一个新的对象 并且返回的对象会被触发者隐式的 retain , 触发者负责释放 一般来说返回的对象都是不可变的
  • mutableCopyWithZone: 会返回一个新的对象 并且返回的对象会被触发者隐式的 retain , 触发者负责释放, 一般来说返回的对象都是可变的

参考:apple 文档

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Java中,集合拷贝构造函数通常只提供浅拷贝,而不是深拷贝。这意味着原始集合和克隆集合中存储的对象是相同的,指向Java堆内存中相同的位置。如果修改了原始集合中的对象信息,克隆集合也会受到影响,反之亦然。所以,如果需要进行集合的深拷贝,需要采用其他方法。 一个可行的深拷贝集合的方法是使用递归来克隆集合中的对象,直到基本数据类型或者不可变类。这个过程可以通过创建一个新的集合对象,并将原始集合中的每个元素逐个克隆并添加到新的集合中。这样就可以确保克隆集合与原始集合完全独立。然后就可以对克隆集合进行任意的修改,而不会对原始集合产生任何影响。 在给定的引用中,展示了一个使用递归方法来进行深拷贝的示例代码。该示例代码是一个求取整数数组的所有子集的方法,其中使用了递归来生成子集。递归的过程中,通过创建新的集合对象,并将原始集合中的元素逐个添加到新的集合中,实现了深拷贝的效果。 因此,要进行Java集合的深拷贝,可以使用递归方法来克隆集合中的对象,确保克隆集合与原始集合完全独立。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [java中list集合的深度拷贝](https://blog.csdn.net/u010398493/article/details/52840076)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值