python 拷贝 深拷贝 浅拷贝 赋值
t = [1,["a","b"]]
t_bak = t
t_cop = copy.copy(t)
t_deep = copy.deepcopy(t)
print("id(t)--- "+str(id(t))+" id(t[1]) " +str(id(t[1])) +" id(t[1][1] 也就是 内部列表中的第二个元素"+str(id(t[1][1])))
print("id(t_bak)--- "+str(id(t_bak))+" id(t_bak[1]) " +str(id(t_bak[1])) +" id(t_bak[1][1] 也就是 内部列表中的第二个元素"+str(id(t_bak[1][1])))
print("id(t_copy)--- "+str(id(t_cop))+" id(t_cop[1]) " +str(id(t_cop[1])) +" id(t_cop[1][1] 也就是 内部列表中的第二个元素"+str(id(t_cop[1][1])))
print("id(t_deep)--- "+str(id(t_deep))+" id(t_deep[1]) " +str(id(t_deep[1])) +" id(t_deep[1][1] 也就是 内部列表中的第二个元素"+str(id(t_deep[1][1])))
id(t)--- 140706556438648 id(t[1]) 140706556410336 id(t[1][1] 也就是 内部列表中的第二个元素140706557474336
id(t_bak)--- 140706556438648 id(t_bak[1]) 140706556410336 id(t_bak[1][1] 也就是 内部列表中的第二个元素140706557474336
id(t_copy)--- 140706534860560 id(t_cop[1]) 140706556410336 id(t_cop[1][1] 也就是 内部列表中的第二个元素140706557474336
id(t_deep)--- 140706556438576 id(t_deep[1]) 140706556439656 id(t_deep[1][1] 也就是 内部列表中的第二个元素140706557474336
可以看到, t 和t_bak 这种直接赋值的操作,其实指向的是同一个对象,无论是第一层,还是内部嵌套的元素
而 t 和 t_cop 这种copy操作,第一层的id已经不一样了,说明他们创建了新的对象,但是内部嵌套的元素还是一致的,说明给他们内部嵌套指向的是同一个对象。
再说 t 和t_deep 这种deepcopy 深拷贝操作,发现,第一层已经不一样了,说明创建了新的对象,但是内部嵌套的元素还是一样的
修改t_bak(1)
t_bak.append("3")
print(t) #[1, ['a', 'b'], '3']
print(t_bak)#[1, ['a', 'b'], '3']
print(t_cop)#[1, ['a', 'b']]
print(t_deep)#[1, ['a', 'b']]
print("id(t)--- "+str(id(t))+" id(t[1]) " +str(id(t[1])) +" id(t[1][1] 也就是 内部列表中的第二个元素"+str(id(t[1][1])))
print("id(t_bak)--- "+str(id(t_bak))+" id(t_bak[1]) " +str(id(t_bak[1])) +" id(t_bak[1][1] 也就是 内部列表中的第二个元素"+str(id(t_bak[1][1])))
print("id(t_copy)--- "+str(id(t_cop))+" id(t_cop[1]) " +str(id(t_cop[1])) +" id(t_cop[1][1] 也就是 内部列表中的第二个元素"+str(id(t_cop[1][1])))
print("id(t_deep)--- "+str(id(t_deep))+" id(t_deep[1]) " +str(id(t_deep[1])) +" id(t_deep[1][1] 也就是 内部列表中的第二个元素"+str(id(t_deep[1][1])))
id(t)--- 139789718802088 id(t[1]) 139789718801728 id(t[1][1] 也就是 内部列表中的第二个元素139789719836192
id(t_bak)--- 139789718802088 id(t_bak[1]) 139789718801728 id(t_bak[1][1] 也就是 内部列表中的第二个元素139789719836192
id(t_copy)--- 139789697222416 id(t_cop[1]) 139789718801728 id(t_cop[1][1] 也就是 内部列表中的第二个元素139789719836192
id(t_deep)--- 139789718802232 id(t_deep[1]) 139789718802376 id(t_deep[1][1] 也就是 内部列表中的第二个元素139789719836192
修改 t_bak(2)
t_bak[1][1]='c'
print(t) #[1, ['a', 'c'],]
print(t_bak)#[1, ['a', 'c']]
print(t_cop)#[1, ['a', 'c']]
print(t_deep)#[1, ['a', 'b']]
id(t)--- 140085180813112 id(t[1]) 140085180812968 id(t[1][1] 也就是 内部列表中的第二个元素140085181848632
id(t_bak)--- 140085180813112 id(t_bak[1]) 140085180812968 id(t_bak[1][1] 也就是 内部列表中的第二个元素140085181848632
id(t_copy)--- 140085159233296 id(t_cop[1]) 140085180812968 id(t_cop[1][1] 也就是 内部列表中的第二个元素140085181848632
id(t_deep)--- 140085180813040 id(t_deep[1]) 140085180812536 id(t_deep[1][1] 也就是 内部列表中的第二个元素140085181847072
这也证明了上述:
浅拷贝创建了一个新的对象,但是内部嵌套的元素仍然和原对象引用的是同一个。
深拷贝,无论内外都重新复制了一份
修改 t_cop
t_cop.append(4)
t_cop[1][1] = 'd'
print(t) #[1, ['a', 'd']]
print(t_bak)##[1, ['a', 'd']]
print(t_cop)#[1, ['a', 'd'], 4]
print(t_deep)#[1, ['a', 'b']]
print("id(t)--- "+str(id(t))+" id(t[1]) " +str(id(t[1])) +" id(t[1][1] 也就是 内部列表中的第二个元素"+str(id(t[1][1])))
print("id(t_bak)--- "+str(id(t_bak))+" id(t_bak[1]) " +str(id(t_bak[1])) +" id(t_bak[1][1] 也就是 内部列表中的第二个元素"+str(id(t_bak[1][1])))
print("id(t_copy)--- "+str(id(t_cop))+" id(t_cop[1]) " +str(id(t_cop[1])) +" id(t_cop[1][1] 也就是 内部列表中的第二个元素"+str(id(t_cop[1][1])))
print("id(t_deep)--- "+str(id(t_deep))+" id(t_deep[1]) " +str(id(t_deep[1])) +" id(t_deep[1][1] 也就是 内部列表中的第二个元素"+str(id(t_deep[1][1])))
id(t)--- 140596834620840 id(t[1]) 140596834621920 id(t[1][1] 也就是 内部列表中的第二个元素140596835776312
id(t_bak)--- 140596834620840 id(t_bak[1]) 140596834621920 id(t_bak[1][1] 也就是 内部列表中的第二个元素140596835776312
id(t_copy)--- 140596813072144 id(t_cop[1]) 140596834621920 id(t_cop[1][1] 也就是 内部列表中的第二个元素140596835776312
id(t_deep)--- 140596834620912 id(t_deep[1]) 140596834651312 id(t_deep[1][1] 也就是 内部列表中的第二个元素140596835685920
修改 t_deep
t_deep.append(5)
t_deep[1][1] = 'e'
print(t) #[1, ['a', 'b']]
print(t_bak)#[1, ['a', 'b']]
print(t_cop)#[1, ['a', 'b']]
print(t_deep)#[1, ['a', 'e'], 5]
print("id(t)--- "+str(id(t))+" id(t[1]) " +str(id(t[1])) +" id(t[1][1] 也就是 内部列表中的第二个元素"+str(id(t[1][1])))
print("id(t_bak)--- "+str(id(t_bak))+" id(t_bak[1]) " +str(id(t_bak[1])) +" id(t_bak[1][1] 也就是 内部列表中的第二个元素"+str(id(t_bak[1][1])))
print("id(t_copy)--- "+str(id(t_cop))+" id(t_cop[1]) " +str(id(t_cop[1])) +" id(t_cop[1][1] 也就是 内部列表中的第二个元素"+str(id(t_cop[1][1])))
print("id(t_deep)--- "+str(id(t_deep))+" id(t_deep[1]) " +str(id(t_deep[1])) +" id(t_deep[1][1] 也就是 内部列表中的第二个元素"+str(id(t_deep[1][1])))
id(t)--- 140579373325560 id(t[1]) 140579373295088 id(t[1][1] 也就是 内部列表中的第二个元素140579374360096
id(t_bak)--- 140579373325560 id(t_bak[1]) 140579373295088 id(t_bak[1][1] 也就是 内部列表中的第二个元素140579374360096
id(t_copy)--- 140579351746320 id(t_cop[1]) 140579373295088 id(t_cop[1][1] 也就是 内部列表中的第二个元素140579374360096
id(t_deep)--- 140579373325488 id(t_deep[1]) 140579373326136 id(t_deep[1][1] 也就是 内部列表中的第二个元素140579374451928
python 拷贝 深拷贝 浅拷贝 赋值的更多相关文章
- Python拷贝(深拷贝deepcopy与浅拷贝copy)
Python中的对象之间赋值时是按引用传递的,如果需要拷贝对象,需要使用标准库中的copy模块. 1.copy.copy 浅拷贝 只拷贝父对象,不会拷贝对象的内部的子对象. 2.copy.deepco ...
- python进阶----深拷贝&浅拷贝
复制需要区分,,复制的是源文件的数据,还是指向源文件数据的地址 1.引用 b=a时,理解为b指向了a指向的数据,相当于引用复制 a=[1,2] b=a #验证复制的是数据还是地址 #1.查看ab的 ...
- Python 拷贝对象(深拷贝deepcopy与浅拷贝copy)
1. copy.copy 浅拷贝 只拷贝父对象,不会拷贝对象的内部的子对象. 2. copy.deepcopy 深拷贝 拷贝对象及其子对象 一个很好的例子: # -*-coding:utf-8 -*- ...
- Python里的赋值 拷贝 深拷贝
import copy a = [1, 2, 3, 4, ['a', 'b']] #原始对象 b = a #赋值,传对象的引用 c = copy.copy(a) #对象拷贝,浅拷贝 d = copy. ...
- python中的浅拷贝和深拷贝
1.赋值语句 a = 'abc' b = a print id(a) print id(b) # id(a):29283464 # id(b):29283464 通过简单的复制,我们可以看到,a b其 ...
- python基础知识5——赋值与深浅拷贝——整数和字符串,列表元组字典
深浅copy 一.数字和字符串 对于 数字 和 字符串 而言,赋值.浅拷贝和深拷贝无意义,因为其永远指向同一个内存地址. 1 import copy 2 # ######### 数字.字符串 #### ...
- python中的浅拷贝与赋值不同
Python中的对象之间赋值时是按引用传递的,如果需要拷贝对象,需要使用标准库中的copy模块. 1. copy.copy 浅拷贝 只拷贝父对象,不会拷贝对象的内部的子对象. 2. copy.deep ...
- python 中 深拷贝和浅拷贝的理解
在总结 python 对象和引用的时候,想到其实 对于python的深拷贝和浅拷贝也可以很好对其的进行理解. 在python中,对象的赋值的其实就是对象的引用.也就是说,当创建一个对象,然后赋给另外一 ...
- python中深拷贝和浅拷贝
python中所谓浅拷贝就是对引用的拷贝,所谓深拷贝就是对对象的资源的拷贝. 首先,对赋值操作我们要有以下认识: 赋值是将一个对象的地址赋值给一个变量,让变量指向该地址( 旧瓶装旧酒 ). 修改不可变 ...
随机推荐
- ZooKeeper系列(8):ZooKeeper伸缩性
一.ZooKeeper中Observer 1.1 ZooKeeper角色 经过前面的介绍,我想大家都已经知道了在ZooKeeper集群当中有两种角色Leader和Follower.Leader可以接受 ...
- Markdown画各种图表
并不是所有编辑器都支持,比如博客园这个就不支持... 流程图 st=>start: 开始 op=>operation: 首先按个按钮 op2=>operation: 那你从头开始吧 ...
- Mapreduce入门和优化方案
MapReduce基本原理和高性能网络下优化: Mapreduce概述 Mapreduce式谷歌开源的一项重要技术,是一个编程模型,用来进行大数据量的计算,对于大数据量的计算通常采用的处理方式式并行计 ...
- SQL with(unlock)与with(readpast)
所有Select加 With (NoLock)解决阻塞死锁,在查询语句中使用 NOLOCK 和 READPAST 处理一个数据库死锁的异常时候,其中一个建议就是使用 NOLOCK 或者 READPAS ...
- 02-spark sql
1.概念 Spark SQL是一个用来处理结构化数据的Spark组件. 优点: ①SparkSQL是一个SQL解析引擎,将SQL解析成特殊的RDD(DataFrame),然后在Spark集群中运行 ...
- appium java 在android7.0真机上测试程序时报错command failed shell "ps 'uiautomator'"的解决方式
1.找到appium的安装目录下的adb.js文件,目录为:Appium\node_modules\appium\node_modules\appium-adb\lib 2.打开adb.js,找到如下 ...
- c# 值类型与引用类型的传参(形参与实参)
形参是指被调用方法中的参数 实参是指传递给方法的参数 (1)值类型传参是按值传递 值类型传参,形参接受到的是实参的一个副本,即形参发生变化,实参不会发生任何变化 (2)引用类型参数按值传递 当参数传递 ...
- nginx安装以及常用配置
nginx的源码安装 0 安装相关软件:yum -y install pcre-devel zlib-devel openssl-devel 1 下载 nginx-1.14.0.tar.gz 2 安装 ...
- 重新指派usb转串口模块在linux系统中的设备调用名称
How to remap /dev/ttyUSB* to a specific name to be called by my program. How to map /dev/ttyUSB* to ...
- 1.Hadoop简单理解与总结。
1.什么是Hadoop? Hadoop是一种分布式数据和计算的框架.它很擅长存储大量的半结构化的数据集.数据可以随机存放,所以一个磁盘的失败并不会带来数据丢失.Hadoop也非常擅长分布式计算——快速 ...