关于Python深浅拷贝
拷贝:
说明:原则上就是把数据分离出来,复制其数据,并以后修改互不影响。
何来深浅拷贝的说法?
深浅拷贝的“深”和“浅”可以理解为从变量到硬盘上的物理存储介质之间的层次的多少。
下面用一个示例来解释浅拷贝:
#Author : Kelvin
#Date : 2019/1/5 0:41
import copy
#浅拷贝的第一种方式(使用对象自身的copy方法)
li1=[["bob","alvin"],"kelvin","alex"]
li2=li1.copy() #调用列表自身方法拷贝
li2[1]="kelvin-sb" #修改li2的第二个元素
print("li1: ",li1)
print("li2: ",li2)
#运行结果(只有li2改变了):
#li1: [['bob', 'alvin'], 'kelvin', 'alex']
# li2: [['bob', 'alvin'], 'kelvin-sb', 'alex']
print("-------"*6)
li2[0][0]="bob-sb" #修改li2的第一个元素中的第一个元素
print("li1: ",li1)
print("li2: ",li2)
#运行结果(li1和li2都改变了):
# li1: [['bob-sb', 'alvin'], 'kelvin', 'alex']
# li2: [['bob-sb', 'alvin'], 'kelvin-sb', 'alex'] #浅拷贝的第二种方式(使用copy模块的copy方法)
li1=[["bob","alvin"],"kelvin","alex"]
li2=copy.copy(li1) #调用copy模块方法拷贝
li2[1]="kelvin-sb" #修改li2的第二个元素
print("li1: ",li1)
print("li2: ",li2)
#运行结果(只有li2改变了):
#li1: [['bob', 'alvin'], 'kelvin', 'alex']
# li2: [['bob', 'alvin'], 'kelvin-sb', 'alex']
print("-------"*6)
li2[0][0]="bob-sb" #修改li2的第一个元素中的第一个元素
print("li1: ",li1)
print("li2: ",li2)
#运行结果(li1和li2都改变了):
# li1: [['bob-sb', 'alvin'], 'kelvin', 'alex']
# li2: [['bob-sb', 'alvin'], 'kelvin-sb', 'alex']
对于上面浅拷贝的示例我们可以看到,当浅拷贝之后,修改其中一个不可变类型元素(数字,字符串等),拷贝前后对象之间互不干扰,没有影响,但是当修改了可变类型元素(列表,字典等),拷贝前后对象均发生改变。其中的原因就是因为不可变类型直接存储在物理硬盘上,而可变类型则会包含多个不可变类型而形成一个独立的内存地址,也就是多了一“层”。下面用图示具体说明:
只改变“kelvin”图示:

改变li1第一个元素(列表)中的值图示:

**注:认真理清图示表达的含义,理解好深浅的内涵。
下面再通过一个示例来了解深拷贝:
import copy
#深拷贝只能调用copy模块的deepcopy方法
li1=[["bob","alvin"],"kelvin","alex"]
li2=copy.deepcopy(li1) #调用copy模块方法拷贝
li2[1]="kelvin-sb" #修改li2的第二个元素
print("li1: ",li1)
print("li2: ",li2)
#运行结果(只有li2改变了):
#li1: [['bob', 'alvin'], 'kelvin', 'alex']
# li2: [['bob', 'alvin'], 'kelvin-sb', 'alex']
print("-------"*6)
li2[0][0]="bob-sb" #修改li2的第一个元素中的第一个元素
print("li1: ",li1)
print("li2: ",li2)
#运行结果(只有li2改变了):
# li1: [['bob', 'alvin'], 'kelvin', 'alex']
# li2: [['bob-sb', 'alvin'], 'kelvin-sb', 'alex']
深拷贝相比较浅拷贝就容易理解的多,因为深拷贝就是完完全全的拷贝,拷贝前后的两个对象占有独立的内存空间,不存在共享空间,因此拷贝前后对象相互改变无影响。
最后来一个深浅拷贝的应用实例(随意实例):
#Author : Kelvin
#Date : 2019/1/5 1:37 import copy
kelvin=["kelvin",123,[10000,]] #户主 卡号 余额
wife=kelvin.copy() #给媳妇共享银行卡
wife[1]=234 #设置媳妇卡号
wife[0]="peiqi" #媳妇银行卡户主
wife[2][0]-=2000 #媳妇消费2000元
print(kelvin)
print(wife)
print("------"*6)
# 输出结果(实现共享账户):
# ['kelvin', 123, [8000]]
# ['peiqi', 234, [8000]] #小三账户不能浅拷贝,因为媳妇会发现账户少钱
xiaosan=copy.deepcopy(kelvin)
xiaosan[0]="sanzi" #小三银行卡户主
xiaosan[1]=666 #设置小三卡号
xiaosan[2][0]-=3000 #小三消费3000元
print(kelvin)
print(xiaosan)
# 输出结果(老婆不会发现):
# ['kelvin', 123, [10000]]
# ['sanzi', 666, [7000]]
关于Python深浅拷贝的更多相关文章
- Python开发【第二章】:Python深浅拷贝剖析
Python深浅拷贝剖析 Python中,对象的赋值,拷贝(深/浅拷贝)之间是有差异的,如果使用的时候不注意,就可能产生意外的结果. 下面本文就通过简单的例子介绍一下这些概念之间的差别. 一.对象赋值 ...
- 小学生都能学会的python(深浅拷贝)
小学生都能学会的python(深浅拷贝) join() 把列表中的每一项用字符串拼接起来 # lst = ["汪峰", "吴君如", "李嘉欣&quo ...
- 【0806 | Day 9】三张图带你了解数据类型分类和Python深浅拷贝
一.数据类型分类 二.Python深浅拷贝
- 底层剖析Python深浅拷贝
底层剖析Python深浅拷贝 拷贝的用途 拷贝就是copy,目的在于复制出一份一模一样的数据.使用相同的算法对于产生的数据有多种截然不同的用途时就可以使用copy技术,将copy出的各种副本去做各种不 ...
- 关于python深浅拷贝的个人浅见
起初,关于python的深浅拷贝,总是习惯去用传值传址的方式去考虑,发现总是get不到规律,容易记混. python有着高度自治的内存管理,而不可变对象的内存分配,则是能省则省,就是说,无论用什么拷贝 ...
- python深浅拷贝与赋值
初学编程的小伙伴都会对于深浅拷贝的用法有些疑问,今天我们就结合python变量存储的特性从内存的角度来谈一谈赋值和深浅拷贝~~~ 预备知识一——python的变量及其存储 在详细的了解python中赋 ...
- python 深浅拷贝 进阶
主要理解新与旧究竟在哪里 这样也就理解了 深浅拷贝 先说说赋值,事实上python中的赋值事实上是赋值了一个引用.比如: foo1=1.0 foo2=foo1 用操作符is推断时.你能够发现结果是tr ...
- python深浅拷贝&垃圾回收&上下文管理(with语句)
深浅拷贝 在Python中使用copy模块用于对象的拷贝操作. 该模块提供了两个主要的方法:浅拷贝 copy.copy() 深拷贝 copy.deepcopy() 1.浅拷贝(copy) 浅拷贝: 不 ...
- python 深浅拷贝 for循环删除
###########################总结########################### 1. 基础数据类型补充 大多数的基本数据类型的知识.已经学完了 a='aaaa' ls ...
随机推荐
- RabbitMQ (三) 发布/订阅
转发请标明出处:http://blog.csdn.net/lmj623565791/article/details/37657225 本系列教程主要来自于官网入门教程的翻译,然后自己进行了部分的修改与 ...
- [python]多线程模块thread与threading
Python通过两个标准库(thread, threading)提供了对多线程的支持 thread模块 import time import thread def runner(arg): for i ...
- Elasticsearch笔记六之中文分词器及自定义分词器
中文分词器 在lunix下执行下列命令,可以看到本来应该按照中文"北京大学"来查询结果es将其分拆为"北","京","大" ...
- java.lang.IllegalArgumentException异常 数据库别名问题
java.lang.IllegalArgumentException: org.hibernate.hql.internal.ast.QuerySyntaxException: Path expect ...
- 单机配置kafka和zookeeper
1:环境准备 jdk 推荐oracle,不建议open sdk 在/etc/profile加入下列环境变量 在PATH中将jdk和jre的bin加入path里面 $JAVA_HOME/bin:$JRE ...
- 【SAP业务模式】之STO(二):系统配置
本篇博文开始讲述STO业务模式的配置! 一.定义发货工厂的装运数据: 目录:SPRO-物料管理-采购-采购订单-设置库存调拨订单-定义工厂的装运数据 定义发货工厂的装运数据: 为收货工厂分配客户代码: ...
- RabbitMQ指南之一:"Hello World!"
为什么要使用MQ消息中间件?它解决了什么问题?关于为什么要使用消息中间件?消息中间件是如何做到同步变异步.流量削锋.应用解耦的?网上已经有很多说明,我这里就不再说明了,读者可以参考(https://w ...
- 【.NET异步编程系列1】:await&async语法糖让异步编程如鱼得水
前导 Asynchronous programming Model(APM)异步编程模型以BeginMethod(...) 和 EndMethod(...)结对出现. IAsyncResult Beg ...
- .NET(WinCE、WM)转Android开发——Xamarin和Smobiler对比
对比 WinCE Android 行业场景 扫描分拣.车载.工控 扫描分拣.车载定位 开发语言 C++.C# Java/.NET(Smobiler) 开发环境 Visual Studio Androi ...
- 基础测试jmeter5.0+badboy(从小白到入门)
1]测试工具jmeter环境安装 1.1]安装jdk环境 1:必须安装jdk8.0(我尝试安装最新版本不行,好像当时没有配置好.之后安装8.0遍可以正常运行)下载地址:单击此段 配置jdk环境:鼠标右 ...