0

0

Python 中“深拷贝”一定安全吗?

冷漠man

冷漠man

发布时间:2026-01-18 18:19:02

|

144人浏览过

|

来源于php中文网

原创

深拷贝存在循环引用、不可序列化对象、自定义类适配及性能副作用四大风险。需检测哈希逻辑、实现__deepcopy__、避免对“活”资源调用,并警惕副作用与开销。

python 中“深拷贝”一定安全吗?

深拷贝并不总是安全的,它能解决大部分对象复制问题,但存在几个关键例外场景,容易引发意外行为甚至崩溃。

循环引用可能导致无限递归

当对象内部存在循环引用(比如 A 持有 B,B 又持有 A),copy.deepcopy 默认会检测并缓存已拷贝的对象,避免死循环。但这依赖于 Python 的递归限制和哈希/可变性判断——如果自定义类重写了 __hash____eq__ 逻辑异常,或包含不可哈希的可变组件(如含列表的字典作为键),deepcopy 可能误判、跳过缓存,进而触发 RecursionError 或静默出错。

  • 检查自定义类是否正确定义了 __hash____eq__
  • 对含复杂嵌套结构的对象,先用 sys.setrecursionlimit() 临时提高限制(慎用)
  • 更稳妥的方式是手动实现 __deepcopy__ 方法,显式控制循环引用处理

不可序列化的对象无法深拷贝

文件对象、线程锁、数据库连接、socket、lambda 函数等“活”资源,本身不支持序列化,deepcopy 会直接抛出 TypeError。这不是 bug,而是设计使然:这些对象代表的是运行时状态,无法被复制。

  • 遇到 TypeError: cannot pickle ... 时,说明对象含不可拷贝成分
  • 可在类中实现 __deepcopy__,对特殊字段跳过拷贝或重新初始化(例如锁 → 新建 threading.Lock())
  • 必要时改用浅拷贝 + 手动重建关键部分,而非强求全量 deep copy

自定义类未适配时行为不可控

如果类没有定义 __deepcopy__,Python 会尝试按默认规则逐个拷贝其 __dict__ 中的属性。但若属性是 C 扩展对象、内存视图(memoryview)、NumPy 数组(某些视图模式),或使用了 __slots__ 且未正确处理描述符,结果可能不是真正独立的副本,而是共享底层缓冲区。

仿淘宝五一落叶微风特别版
仿淘宝五一落叶微风特别版

1. 商品出售包含拍卖模式,一口价模式。2. 全套系统采用淘宝网风格,成熟,简洁大方3. 每个商品支持多张图片上传,可自由设定,满足广大网民的迫切要求4. 商品发布页采用强大的多功能在线编辑器全面支持HTML,多彩文字,图文并茂,并支持直接从WORD中拷贝5.店铺中心支持多模板选项,目前带有两种风格。6.支持求购信息分类检索和地区检索7. 系统整合网银在线支付功能,使交易更方便,安全快捷8. 拥有

下载

立即学习Python免费学习笔记(深入)”;

  • 使用 NumPy 时优先调用 .copy() 而非 copy.deepcopy
  • __slots__ 的类应显式在 __deepcopy__ 中处理 slot 属性
  • 对内存敏感场景(如图像处理、科学计算),用 id()np.shares_memory() 验证是否真隔离

性能与副作用隐患

deepcopy 是深度遍历操作,时间与空间开销都随嵌套层级和对象数量增长。更隐蔽的问题是:如果对象的 __init____new__ 或某些属性的 getter 触发了副作用(如写日志、发请求、修改全局状态),deepcopy 过程中可能意外执行这些逻辑。

  • 避免在构造函数或属性访问中埋入副作用
  • 对高开销或带副作用的对象,考虑用工厂函数替代 deepcopy
  • copy.copy + 关键字段手动重建,往往比盲目 deep copy 更可控

深拷贝是强大工具,但不是银弹。理解它的工作边界,比记住“用 deepcopy 就安全”更重要。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

759

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

639

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

761

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

618

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1265

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

548

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

579

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

709

2023.08.11

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

65

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 3.5万人学习

Django 教程
Django 教程

共28课时 | 3.2万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号