拷贝:

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

何来深浅拷贝的说法?

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

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

 #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. 用Axure进行原型设计

    用Axure进行原型设计   看这个视频 http://www.iqiyi.com/playlist409963402.html

  2. 【k短路&A*算法】BZOJ1975: [Sdoi2010]魔法猪学院

    Description 找出1~k短路的长度.   Solution k短路的求解要用到A*算法 A*算法的启发式函数f(n)=g(n)+h(n) g(n)是状态空间中搜索到n所花的实际代价 h(n) ...

  3. BZOJ_5015_[Snoi2017]礼物_矩阵乘法

    BZOJ_5015_[Snoi2017]礼物_矩阵乘法 Description 热情好客的请森林中的朋友们吃饭,他的朋友被编号为 1-N,每个到来的朋友都会带给他一些礼物:.其中,第 一个朋友会带给他 ...

  4. csc.exe的环境变量设置

    csc.exe使用来编译*.cs文件的,但必须要在安装目录下使用.所以需要设置一下环境变量. C#的环境变量设置 1.“win+R” 打开运行窗口,并输入 “cmd”: 2.运行“set path=% ...

  5. selenium IDE中log的保存与查看方法

    下载selenium IDE的log保存插件为File Logging(selenium IDE),下载安装方式如下: (1)打开firefox浏览器----点击右上角----附加组件---插件--- ...

  6. 若干排序算法的Python实现方法及原理

    今天突然想到了一个问题:让你立即把堆排.快排等等排序算法写出来会不会,并且不能犯逻辑错误? 我说:不会,至少需要思考一下,并且可能还需要时间调试. 之前总是觉得,不就是排序算法吗?有什么大不了的?网上 ...

  7. 轻量化卷积神经网络MobileNet论文详解(V1&V2)

    本文是 Google 团队在 MobileNet 基础上提出的 MobileNetV2,其同样是一个轻量化卷积神经网络.目标主要是在提升现有算法的精度的同时也提升速度,以便加速深度网络在移动端的应用.

  8. 启动链码报rpc error: code = Unimplemented desc = unknown service protos.ChaincodeSupport start error

    参考链接:https://stackoverflow.com/questions/48007519/unimplemented-desc-unknown-service-protos-chaincod ...

  9. 深入理解Java 栈数据结构

    栈(stack)又名堆栈,它是一种运算受限的线性表.其限制是仅允许在表的一端进行插入和删除运算.这一端被称为栈顶,相对地,把另一端称为栈底.向一个栈插入新元素又称作进栈.入栈或压栈,它是把新元素放到栈 ...

  10. Mendeley使用小技巧

    合并重复论文 在导入论文时,可能出现新导入的一篇论文是自己之前看过的,但是可能因为某些原因,如来源不是同一个网址,arxiv 和 ICCV,两篇相同内容的文献同时存在. Mendeley 提供一个方法 ...