看了别人的博客,自己实践一下,记录下来。
例子1:
“is” 是比较a 和 b是不是指向同一个内存单元,而“==”是用来比较a 和 b指向的内存单元中的值是不是相等。
例子2:
与上面的例子相比,只是a 和 b的值变了,居然结果不同了,a 和 b 的地址居然是一样的!
原因是 python的垃圾回收机制有一个小整数对象池存储了 [-5,256] 的整数,程序要用这个区间的整数就会直接指向对象池中的同一份数据,所以地址都是一样的,程序要用这个区间以外的数时才会新申请一块内存,用来存储数据。
例子3 :
对于数值类型的数据,只要两个数据大小相等,那么就是相等,但是对于非数值型的数据,比如字符串,类创建的对象又是比较什么呢?答案是python默认去比较两个对象的地址:
class Person:
def __init__(self):
self.name = 'mac'
self.age = 24
p1 = Person()
p2 = Person()
print(id(p1))
print(id(p2))
print(p1 == p2)
#输出
4490862264
4490862432
False
我们发现上图中,p1和p2两个对象的内容完全相同,但是python编译器却认为其不相等,这个时候就需要我们自己去定义规则去规定在什么条件下两个对象是相等的,具体操作需要去重写python中的eq方法,通常把这个过程叫做运算符重载。下面这张图就是完成运算符重载之后的操作,我们发现这时候两个对象的值是相等的。
class Person:
def __init__(self,name,age):
self.name = name
self.age = age
def __eq__(self, other):
return self.name == other.name and self.age == other.age
p1 = Person('yo',24)
p2 = Person('yo',24)
print(id(p1))
print(id(p2))
print(p1 == p2)
#输出
4440522480
4440522536
True
注意,这里就用到了 __equa__
方法的重载,虽然p1 和 p2 的地址不同,但是解释器认为他们是相同的.