拷贝:

  说明:原则上就是把数据分离出来,复制其数据,并以后修改互不影响。

何来深浅拷贝的说法?

  深浅拷贝的“深”和“浅”可以理解为从变量到硬盘上的物理存储介质之间的层次的多少。

下面用一个示例来解释浅拷贝:

 #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深浅拷贝的更多相关文章

  1. Python开发【第二章】:Python深浅拷贝剖析

    Python深浅拷贝剖析 Python中,对象的赋值,拷贝(深/浅拷贝)之间是有差异的,如果使用的时候不注意,就可能产生意外的结果. 下面本文就通过简单的例子介绍一下这些概念之间的差别. 一.对象赋值 ...

  2. 小学生都能学会的python(深浅拷贝)

    小学生都能学会的python(深浅拷贝) join() 把列表中的每一项用字符串拼接起来 # lst = ["汪峰", "吴君如", "李嘉欣&quo ...

  3. 【0806 | Day 9】三张图带你了解数据类型分类和Python深浅拷贝

    一.数据类型分类 二.Python深浅拷贝

  4. 底层剖析Python深浅拷贝

    底层剖析Python深浅拷贝 拷贝的用途 拷贝就是copy,目的在于复制出一份一模一样的数据.使用相同的算法对于产生的数据有多种截然不同的用途时就可以使用copy技术,将copy出的各种副本去做各种不 ...

  5. 关于python深浅拷贝的个人浅见

    起初,关于python的深浅拷贝,总是习惯去用传值传址的方式去考虑,发现总是get不到规律,容易记混. python有着高度自治的内存管理,而不可变对象的内存分配,则是能省则省,就是说,无论用什么拷贝 ...

  6. python深浅拷贝与赋值

    初学编程的小伙伴都会对于深浅拷贝的用法有些疑问,今天我们就结合python变量存储的特性从内存的角度来谈一谈赋值和深浅拷贝~~~ 预备知识一——python的变量及其存储 在详细的了解python中赋 ...

  7. python 深浅拷贝 进阶

    主要理解新与旧究竟在哪里 这样也就理解了 深浅拷贝 先说说赋值,事实上python中的赋值事实上是赋值了一个引用.比如: foo1=1.0 foo2=foo1 用操作符is推断时.你能够发现结果是tr ...

  8. python深浅拷贝&垃圾回收&上下文管理(with语句)

    深浅拷贝 在Python中使用copy模块用于对象的拷贝操作. 该模块提供了两个主要的方法:浅拷贝 copy.copy() 深拷贝 copy.deepcopy() 1.浅拷贝(copy) 浅拷贝: 不 ...

  9. python 深浅拷贝 for循环删除

    ###########################总结########################### 1. 基础数据类型补充 大多数的基本数据类型的知识.已经学完了 a='aaaa' ls ...

随机推荐

  1. 安装scrapy出错Failed building wheel for Twisted

    用64位windows10的CMD命令安装pip install scrapy出错: Running setup.py bdist_wheel for Twisted ... error Failed ...

  2. Redis Rpop 命令

    Redis Rpop 命令用于移除并返回列表的最后一个元素. 语法 redis Rpop 命令基本语法如下: redis 127.0.0.1:6379> RPOP KEY_NAME 可用版本 & ...

  3. 转载:python + requests实现的接口自动化框架详细教程

    转自https://my.oschina.net/u/3041656/blog/820023 摘要: python + requests实现的接口自动化框架详细教程 前段时间由于公司测试方向的转型,由 ...

  4. 十条有用的GO技术

    十条有用的 Go 技术 这里是我过去几年中编写的大量 Go 代码的经验总结而来的自己的最佳实践.我相信它们具有弹性的.这里的弹性是指: 某个应用需要适配一个灵活的环境.你不希望每过 3 到 4 个月就 ...

  5. MDK5使用Jlink下载显示 no cortex m sw divice 解决办法

    问题: (1)下面界面中找不到设备 (2)下载程序的时候提示" no cortex m sw divice " 然后是"target dll has been cance ...

  6. 关于table表格 td里内容较多换行的处理方法

    最近在用table的时候由于td内容较多默认换行了,很不美观.于是找到处理方法: 在声明table的时候添加一个样式: <table id="tbOffice" data-r ...

  7. Chapter1:基础

    整本书的核心:语言的设计与实现 我们所看到的设计是显示的,语法定义的, 而实现是隐式的,决定了编译或运行时的行为. 了解设计的目的,可以推测实现的细节,也可以自己实现设计. 学习具体的实现,更充分的达 ...

  8. 小白学习Python之路---re模块学习和挑战练习

    本节大纲: 1.正则表达式 2.re模块的学习 3.速记理解技巧 4.挑战练习--开发一个简单的python计算器 5.心得总结 6.学习建议 正则表达式: 正则表达式,又称规则表达式.(英语:Reg ...

  9. 基于思科模拟器的AAA配置与验证

    拓扑图: 地址表如图所示 三个路由器之间采用ospf协议达到互通 先做ping通测试 由ApingB 由ApingC 配置AAA认证 在R1上 R1(config)#username shuaiqiy ...

  10. ASP.NET Core的实时库: SignalR -- 预备知识

    大纲 本系列会分为2-3篇文章. 第一篇介绍SignalR的预备知识和原理 然后会介绍SignalR和如何在ASP.NET Core里使用SignalR. 本文的目录如下: 实时Web简述 Long ...