python的深浅拷贝

本文介绍了Python中的copy函数和deepcopy函数,以及它们在处理可变对象和不可变对象时的区别。浅拷贝仅拷贝对象的第一层,而深拷贝会递归拷贝所有层次。对于不可变对象,无论是浅拷贝还是深拷贝都只是引用赋值。文章通过代码示例展示了这两种拷贝方式在不同场景下的行为。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

copy函数是浅拷贝,只对可变类型的第一层对象进行拷贝,对拷贝的对象开辟新的内存空间进行存储,不会拷贝对象内部的子对象。对于不可变对象而言,浅拷贝只是引用赋值。

deepcopy函数是深拷贝,对于可变类型,深拷贝是逐层进行拷贝。对于不可变类型而言,也是引用赋值。

代码示范:

# 对于可变对象,浅拷贝只拷贝第一层数据,深拷贝会逐层拷贝
# 对于不可变对象来说,无论深浅拷贝 都不会进行拷贝,只是引用赋值
a = 1
b = a
print(a)
print(b)
print(id(a))
print(id(b))

 

 

 

# 当对不可变对象,进行赋值时,不会改变原值内容,会开辟一个新空间并指向
a = 2
print(a)
print(b)
print(id(a))
print(id(2))
print(id(b))
print(id(1))

 

# 不可变对象拷贝时
a = 1
b = copy.copy(a) # 浅拷贝
print(id(1))
print(id(a))
print(id(b))

c = copy.deepcopy(a)
print(id(c))
 

 

可变对象中保存不可变数据

# 可变对象中保存的是不可变数据
cl1 = [1,2,3,'a','b']

cl2 = copy.copy(cl1)

# 如果拷贝成功 值相等 地址不同
print(cl1)
print(cl2)
print(id(cl1))
print(id(cl2))


cl1[0] = 111

print(cl1)
print(cl2)
print(id(cl1))
print(id(cl2))

 

cl1 = [1,2,3,'a','b']

cl2 = copy.deepcopy(cl1)

print(cl1)
print(cl2)
print(id(cl1))
print(id(cl2))


cl1[0] = 111

print(cl1)
print(cl2)
print(id(cl1))
print(id(cl2))

 

可变对象中,保存的可变数据

# 可变对象中 保存的可变数据
a = [1,2]
cl1 =[3,a]
cl2 = copy.copy(cl1)

print(cl1)
print(cl2)
print(id(cl1))
print(id(cl2))

cl1[1][0] = 11
print(cl1)
print(cl2)
print(id(cl1))
print(id(cl2))

 

a = [1,2]
cl1 =[3,a]
cl2 = copy.deepcopy(cl1)

print(cl1)
print(cl2)
print(id(cl1))
print(id(cl2))

cl1[1][0] = 11
print(cl1)
print(cl2)
print(id(cl1))
print(id(cl2))

 

 

 

 

 

 

 

 

 

 

 

### 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]。 #### 总结 - **浅拷贝**只复制顶层的对象,并保留对其余部分(尤其是可变类型如列表或字典等)的引用关系。 - **深拷贝**则完全独立地重建整个层次结构树形图谱下的每一个节点实例化版本。 选择哪种方式进行操作取决于具体的应用需求以及目标数据集本身的特性等因素考虑决定最佳实践方案。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值