当前位置: 首页 > news >正文

python 浅拷贝和深拷贝

  • 浅拷贝(Shallow Copy)
    • 语法
    • 示例代码 1
    • 示例代码 2
  • 深拷贝(Deep Copy)
    • 语法
    • 示例代码
  • 浅拷贝与深拷贝的区别
    • 示例:浅拷贝与深拷贝的对比

  • 浅拷贝:只复制外层容器,内层嵌套对象仍然是共享的,适用于只关心外层数据的场景。
  • 深拷贝:递归地复制整个对象及其内部所有嵌套对象,适用于需要完全独立副本的情况。

浅拷贝(Shallow Copy)

浅拷贝是指创建一个新的对象,但对于对象内部的元素(如列表、字典中的项等),只是引用了原始对象中的元素,而不是创建新的元素。

因此,浅拷贝的对象与原始对象共享内部的可变元素。如果修改了内部元素的值,两个对象都会受到影响。

语法

浅拷贝常通过以下几种方式实现:

  • copy.copy():通过 copy 模块的 copy() 函数创建浅拷贝。
  • list.copy():对于列表,可以使用 list.copy() 方法。
  • dict.copy():对于字典,可以使用 dict.copy() 方法。
  • 列表的切片 [:]:通过切片创建一个浅拷贝。

示例代码 1

import copy

# 使用 copy.copy()
original = [[1, 2], [3, 4]]  # 内部元素是列表,列表是可变元素
shallow_copy = copy.copy(original)

# 修改 shallow_copy 中的内部元素
shallow_copy[0][0] = 6

# 观察两个对象的变化
print("Original:", original)  # Original: [[6, 2], [3, 4]]
print("Shallow Copy:", shallow_copy)  # Shallow Copy: [[6, 2], [3, 4]]
  • 这里,originalshallow_copy 是两个独立的对象,但它们的内部列表是共享的。
  • 修改 shallow_copy 中的内部列表元素(shallow_copy[0][0] = 6)也会影响 original 中的相应元素,因为它们指向相同的内部列表。

注意,如果内部元素不是可变元素,那么不改变原来的常数值。

import copy
original = [1,2]
shallow_copy = copy.copy(original)

shallow_copy[0]= 6

print("Original:", original)  # Original: [1, 2]
print("Shallow Copy:", shallow_copy)  # Shallow Copy: [6, 2]

示例代码 2

列表切片new_list = old_list[:] 创建一个新列表,但其中的元素依然是对原始元素的引用。

original = [1, [2, 3]]
shallow_copy = original[:]
shallow_copy[1][0] = 999
print("Original:", original)  # Original: [1, [999, 3]]

深拷贝(Deep Copy)

深拷贝是指创建一个新的对象,同时递归地创建对象中所有嵌套对象的副本

深拷贝的对象与原始对象完全独立,不共享任何子对象。修改深拷贝中的元素不影响原始对象,反之亦然。

语法

深拷贝通过 copy.deepcopy() 函数实现。该函数会递归地创建一个新对象,并复制所有的嵌套对象,确保每一层都是新的对象。

示例代码

import copy

# 使用 copy.deepcopy()
original = [[1, 2], [3, 4]]
deep_copy = copy.deepcopy(original)

# 修改 deep_copy 中的内部元素
deep_copy[0][0] = 999

# 观察两个对象的变化
print("Original:", original)  # Original: [[1, 2], [3, 4]]
print("Deep Copy:", deep_copy)  # Deep Copy: [[999, 2], [3, 4]]

在这个例子中,originaldeep_copy 完全独立。修改 deep_copy 中的元素不会影响到 original,因为它们是完全独立的对象。

浅拷贝与深拷贝的区别

特性浅拷贝 (Shallow Copy)深拷贝 (Deep Copy)
拷贝方式创建新的对象,但对象内部的元素还是原对象的引用创建一个新的对象及其所有嵌套对象的副本
内部对象共享内部对象是共享的,即它们指向相同的内存位置内部对象完全独立,不共享任何内存
修改内部对象的影响修改拷贝中的内部对象会影响原对象修改拷贝中的内部对象不会影响原对象
速度通常比深拷贝快,因为不递归拷贝所有嵌套对象比浅拷贝慢,因为需要递归地拷贝所有对象

示例:浅拷贝与深拷贝的对比

import copy

# 创建原始对象
original = {
    'a': 1,
    'b': [2, 3],
    'c': {'nested': 4}
}

# 浅拷贝
shallow_copy = copy.copy(original)
shallow_copy['b'][0] = 999  # 修改列表中的元素

# 深拷贝
deep_copy = copy.deepcopy(original)
deep_copy['c']['nested'] = 999  # 修改嵌套字典中的元素

print("Original:", original)
print("Shallow Copy:", shallow_copy)
print("Deep Copy:", deep_copy)

输出:

Original: {'a': 1, 'b': [999, 3], 'c': {'nested': 4}}
Shallow Copy: {'a': 1, 'b': [999, 3], 'c': {'nested': 4}}
Deep Copy: {'a': 1, 'b': [999, 3], 'c': {'nested': 999}}
  • 在浅拷贝中,修改 b 列表中的元素会影响原始对象,因为它们共享相同的列表。
  • 在深拷贝中,修改 c 字典中的嵌套对象(nested)不会影响原始对象,因为 deepcopy 创建了完全独立的副本。

相关文章:

  • Java并发中的CAS机制:原理、应用与挑战(通俗易懂版)
  • 【含文档+PPT+源码】基于微信小程序的乡村振兴民宿管理系统
  • c# sqlite 批量生成insert语句的函数
  • ubuntu基于docker部署呼叫中心质检【支持情绪,话术对比】
  • 计算机组成原理—— 总线系统(十一)
  • DeepSeek HuggingFace 70B Llama 版本 (DeepSeek-R1-Distill-Llama-70B)
  • 【MediaTek】 T750 openwrt-23.05编 cannot find dependency libexpat for libmesode
  • 对比 LVS 负载均衡群集的 NAT 模式和 DR 模式,比较其各自的优势 , 基于 openEuler 构建 LVS-DR 群集。
  • 【linux】文件与目录命令 - cut
  • 微信小程序地图标记点,安卓手机一次性渲染不出来的问题
  • node.js下载、安装、设置国内镜像源(永久)(Windows11)
  • 【愚公系列】《Python网络爬虫从入门到精通》008-正则表达式基础
  • 服务器延迟给视频网站造成的影响
  • RAG科普文!检索增强生成的技术全景解析
  • 基于SSM+uniapp的购药小程序+LW示例参考
  • 元学习之孪生网络Siamese Network
  • Whisper+T5-translate实现python实时语音翻译
  • 【MySQL】高频 SQL 50 题(基础版)
  • 每日一题——矩阵最长递增路径
  • 算法-哈希表03-快乐数
  • 网站封面怎么做/搭建一个app平台要多少钱
  • 微商的自己做网站叫什么名字/百度指数免费查询入口
  • 网站建设项目分析/百度竞价排名服务
  • 电商型企业网站建设/推广普通话奋进新征程手抄报
  • 用自己电脑做服务器 网站吗/百度代运营推广
  • 辽阳网站建设多少钱/微信朋友圈广告推广