copy见解

拷贝就是拷贝,何来深浅之说?

Python中,对象的赋值,拷贝(深/浅拷贝)之间是有差异的,如果使用的时候不注意,就可能产生意外的结果

其实这个是由于共享内存导致的结果

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

先看 一个非拷贝的例子

=赋值:数据完全共享(=赋值是在内存中指向同一个对象,如果是可变(mutable)类型,比如列表,修改其中一个,另一个必定改变

如果是不可变类型(immutable),比如字符串,修改了其中一个,另一个并不会变

l1 = [1, 2, 3, ['aa', 'bb']]

l2 = l1l2[0]='aaa'

l2[3][0]='bbb'

print(l1)  

#['aaa', 2, 3, ['bbb', 'bb']]

print (id(l1)==id(l2))  #True

 l2 = l1 ,l1 完全赋值给l2 ,l2的内存地址与l1 相同,即内存完全指向


浅拷贝:数据半共享(复制其数据独立内存存放,但是只拷贝成功第一层)

l1= [1,2,3,[11,22,33]]

l2 = l1.copy()

print (l2)

#[1,2,3,[11,22,33]]

l2[3][2]='aaa'

print (l1)

#[1, 2, 3, [11, 22, 'aaa']]

print (l2)

#[1, 2, 3, [11, 22, 'aaa']]

l1[0]= 0

print (l1)

#[0, 2, 3, [11, 22, 'aaa']]

print (l2)

#[1, 2, 3, [11, 22, 'aaa']]

print (id(l1)==id(l2)) #Flase

如上述代码,l2浅拷贝了l1 ,之后l2把其列表中的列表的元素给修改,从结果看出,l1也被修改了。但是仅仅修改l1列表中的第一层元素,却并没有影响l2。

比较一下l2与l1的内存地址:False,说明,l2在内存中已经独立出一部分复制了l1的数据,但是只是浅拷贝,第二层的数据并没有拷贝成功,而是指向了l1中的第二层数据的内存地址,所以共享内存‘相当于‘’等号赋值’‘,所以就会有l2中第二层数据发生变化,l1中第二层数据也发生变化

如图,这就是浅拷贝的原理,l2拷贝l1的时候只拷贝了他的第一层,也就是在其他内存中重新创建了l1的第一层数据,但是l2无法拷贝l1的第二层数据,也就是列表中的列表,所以他就只能指向l1中的第二层数据

由此,当修改l1中第二层数据的时候,浅拷贝l1的l2中的第二层数据也随之发生改变


深拷贝:数据完全不共享(复制其数据完完全全放独立的一个内存,完全拷贝,数据不共享)

 深拷贝就是完完全全复制了一份,且数据不会互相影响,因为内存不共享。

深拷贝的方法有

导入模块

import copy

l1 = [1, 2, 3, [11, 22, 33]]#

l2 = copy.copy(l1) 

#浅拷贝

l2 = copy.deepcopy(l1)

print(l1,'>>>',l2)

l2[3][0] = 1111

print(l1,">>>",l2)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Python语言特性 1 Python的函数参数传递 看两个如下例子,分析运行结果: 代码一: a = 1 def...
    伊森H阅读 8,242评论 0 15
  • Python语言特性 1 Python的函数参数传递 看两个如下例子,分析运行结果: 代码一: a = 1 def...
    时光清浅03阅读 3,443评论 0 0
  • 集合,深浅copy 一、集合 集合是无序的,不重复的数据集合,它里面的元素是可哈希的(不可变类型),但是集合本身是...
    go以恒阅读 1,697评论 0 0
  • http://python.jobbole.com/85231/ 关于专业技能写完项目接着写写一名3年工作经验的J...
    燕京博士阅读 12,236评论 1 118
  • 感情路上,总是困难重重,酸甜苦辣百味交杂。 而我想说的是,有时候人真的可能就是犯贱,还是贱到骨子里那种。 都说...
    小九的笑容背后阅读 3,280评论 0 2

友情链接更多精彩内容