python 赋值 比较 深浅copy

赋值运算、对象的比较判断

对象的三个要素id,类型,值。id 指的是内存地址,id 相同则两个对象完全相同

=  赋值运算,a = b,指的是b 的id 与a 相同,b 的数据与a 指向相同的内存空间

is  判断,返回true/false,a is b 判断a 与 b 的id 是否相同

==     判断,等号两边的值相等

练习1

  a = "123"

  b = "123"

  a is b  >>  True  #a 、b 为字符串、数字等不变的数据类型时,如果a b 相同则 ,a b 对应的是同一个id。

  c = [1,2,3]

  d = [1,2,3]

  c == d  >> True  #双等号比较的是两个对象的值是否相同,不考虑它们的类型和id

  c is d  >> False  #当对象为列表、元祖、字典等类型数据时即使相同但也会存放在不同的内存空间,所以c d 的id 不一样

  e = d

  d is e  >> True  #当不管d 为什么数据类型,e=d 就是把e 的数据指针指向d 的内存空间,也是e 与d 使用相同的数据,相同的id

深浅拷贝

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

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中第二层数据也发生变化

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

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)

  

  

  

     

     

猜你喜欢

转载自www.cnblogs.com/fanggege/p/10442316.html