时间:2021-05-22
程序中常常需要复制一个对象, 按思路应该是这样的
a = [1, 2, 3]b = a# [1, 2, 3]print b已经复制好了,但是现在得改变一下第一个元素的值把它改成5
b[0] = 5 # [5, 2, 3]print b # [5, 2, 3]print a我改变了b的第一个元素的值,但是a的值也改变了,这是因为python中的=是引用.a和b指向的是相同的列表,所以改变列表会出现以上的结果.
解决方法是切片操作
a = [1, 2, 3]b = a[:]b[0] = 4# [1, 2, 3]# [4, 2, 3]print aprint b但是在嵌套列表的时候呢,试一试
a = [[1,2,3], 4, 5]b = a[:]b[1] = 0 # [[1,2,3], 4, 5]# [[1,2,3], 0, 5]print aprint b恩!没什么问题,在试一试嵌套列表元素
a = [[1,2,3], 4, 5]b = a[:]b[0][0] = 5# [[5,2,3], 4, 5]# [[5,2,3], 4, 5]print aprint bb = a[:]a的值还是改变了,切片复制只对该对象进行拷贝不会对子元素进行拷贝
copy 模块
copy模块用于对象的拷贝操作。该模块非常简单,只提供了两个主要的方法: copy.copy 与 copy.deepcopy ,分别表示浅复制与深复制。什么是浅复制,什么是深复制,网上有一卡车一卡车的资料,这里不作详细介绍。复制操作只对复合对象有效。用简单的例子来分别介绍这两个方法。
浅复制只复制对象本身,没有复制该对象所引用的对象。
#coding=gbkimport copyl1 = [1, 2, [3, 4]]l2 = copy.copy(l1)print l1print l2l2[2][0] = 50print l1print l2结果:
同样的代码,使用深复制,结果就不一样:
import copyl1 = [1, 2, [3, 4]]l2 = copy.deepcopy(l1)print l1print l2l2[2][0] = 50print l1print l2结果:
改变copy的默认行为
在定义类的时候,通过定义__copy__和__deepcopy__方法,可以改变copy的默认行为。下面是一个简单的例子:
class CopyObj(object): def __repr__(self): return "CopyObj" def __copy__(self): return "Hello"obj = CopyObj()obj1 = copy.copy(obj)print objprint obj1结果:
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在Python中,经常要对一个list进行复制。对于复制,自然的就有深拷贝与浅拷贝问题。深拷贝与浅拷贝的区别在于,当从原本的list复制出新的list之后,修改
直接赋值:其实就是对象的引用(别名)。浅拷贝(copy):拷贝父对象,不会拷贝对象的内部的子对象。深拷贝(deepcopy):copy模块的deepcopy方法
定义直接赋值:就是对象的引用(别名)浅拷贝(copy):拷贝父对象,不拷贝对象内部的子对象深拷贝(deepcopy):copy模块的deepcopy方法,完全拷
对象的深拷贝与浅拷贝的区别如下:浅拷贝:仅仅复制对象的引用,而不是对象本身;深拷贝:把复制的对象所引用的全部对象都复制一遍。一.浅拷贝的实现浅拷贝的实现方法比较
java深拷贝与浅拷贝机制详解概要:在Java中,拷贝分为深拷贝和浅拷贝两种。java在公共超类Object中实现了一种叫做clone的方法,这种方法clone