python 深浅拷贝

1、浅拷贝

  • 浅拷贝:是只拷贝数据的第一层数据

如:


lis = [['你好', '世界'], 1, 3]
copy = lis.copy()  # 拷贝 lis 内容
print(copy)
#  修改第一层数据
copy[1] = 666
#  这里可以看到,在浅拷贝时,修改第一层的内容时,是不会影响到原数据的
#  在lis中  1和3 属于第一层的数据, '你好', '世界' 属于第二层的数据
print(copy) 
print(lis)

'''
结果:
    [['你好', '世界'], 1, 3]
    [['你好', '世界'], 666, 3]
    [['你好', '世界'], 1, 3]
'''
lis = [['你好', '世界'], 1, 3]
copy = lis.copy()  # 拷贝 lis 内容
print(copy)
# 修改第二层数据 ['你好', '世界'] 内的 你好
copy[0][0] = 'list'
# 查看修改后结果
print(copy)  # [['list', '世界'], 1, 3]
#  这里可以看到,在浅拷贝时,是不能修改第二层的内容的,如果修改了,等于把原数据一并修改了
print(lis)  # [['list', '世界'], 1, 3]

'''
结果:
    [['你好', '世界'], 1, 3]
	[['list', '世界'], 1, 3]
	[['list', '世界'], 1, 3]
'''

在这里插入图片描述

2、深拷贝

  • 深拷贝:是拷贝数据的所有内容 (克隆了一份内容)
  • 深拷贝是两份独立的内存,彼此是不受影响的

如:

import copy

lis = [['你好', '世界'], 1, 3]

lis_deep = copy.deepcopy(lis)  # 深拷贝

lis_deep[0][1] = '中国'

print(lis_deep)

print(lis)

'''
结果:
	[['你好', '中国'], 1, 3]
	[['你好', '世界'], 1, 3]

'''

### Python中的深拷贝与浅拷贝 Python 提供了两种复制对象的方式:浅拷贝(shallow copy)和深拷贝(deep copy)。这两种方式在处理复杂数据结构时表现不同,因此理解两者的区别至关重要。 #### 一、浅拷贝 (Shallow Copy) 浅拷贝是指创建一个新的复合对象,然后将原始对象内部的引用插入到新对象中。这意味着如果原对象包含其他容器类型的子对象,则这些子对象不会被复制,而是共享相同的内存地址[^1]。 以下是一个简单的例子展示了列表的浅拷贝行为: ```python import copy original_list = [1, 2, [3, 4]] shallow_copied_list = copy.copy(original_list) original_list[2][0] = 'Modified' print("Original List:", original_list) # Output: Original List: [1, 2, ['Modified', 4]] print("Shallow Copied List:", shallow_copied_list) # Output: Shallow Copied List: [1, 2, ['Modified', 4]] ``` 可以看到,在修改 `original_list` 的嵌套列表之后,`shallow_copied_list` 中对应的嵌套列表也被改变了,因为两者指向的是同一个内存位置。 #### 二、深拷贝 (Deep Copy) 相比之下,深拷贝不仅会创建新的外部容器,还会递归地复制所有的子对象。这样即使修改了原来的对象也不会影响到它的副本[^2]。 下面是同样的场景下使用深拷贝的结果对比: ```python import copy original_list = [1, 2, [3, 4]] deep_copied_list = copy.deepcopy(original_list) original_list[2][0] = 'Modified' print("Original List:", original_list) # Output: Original List: [1, 2, ['Modified', 4]] print("Deep Copied List:", deep_copied_list) # Output: Deep Copied List: [1, 2, [3, 4]] ``` 在这里可以看出,尽管我们更改了 `original_list` 内部的一个元素,但是由于采用了深拷贝策略,所以 `deep_copied_list` 并未受到影响[^2]。 #### 总结 - **浅拷贝**只复制顶层的对象,并保留对其余部分(尤其是可变类型如列表或字典等)的引用关系。 - **深拷贝**则完全独立地重建整个层次结构树形图谱下的每一个节点实例化版本。 选择哪种方式进行操作取决于具体的应用需求以及目标数据集本身的特性等因素考虑决定最佳实践方案。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值