赋值运算、对象的比较判断
对象的三个要素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)