is, in与==
意义
a = [1 , 2 , 3 ]
b = [1 , 2 , 3 ]
print(a == b)
is
比较的是两个对象是不是同一个实例对象,它们的内存地址是否相同
a = [1 , 2 , 3 ]
b = [1 , 2 , 3 ]
print(a is b)
b = a
print(a is b)
in
是判断是否包含,即判断一个集合(如list、tuple
)是否包含这个元素,a in a
是False
是因为[1, 2, 3]
这个列表并不在[1, 2, 3]
这个列表中,[1, 2, 3]
这个列表包含的元素只有1, 2, 3
a = [1 , 2 , 3 ]
print(1 in a)
print(a in a)
注意点
通常我们见到的都是==
而很少见到is
,那么什么时候使用is
呢?当在变量和单例值之间比较时,用is
的效率更高。目前最常使用is
的地方是判断对象是否为None
。is
的效率更高是因为它不能进行函数重载,不用进行特殊的函数调用,直接比较两个对象的id;而==
则调用了对象的__eq__()
方法,继承自object
的对象的__eq__()
方法直接比较两个对象的id,这结果与is
一样,但大多数时候继承object
的类会覆盖__eq__()
方法,因此比较的就是对象的值了,效率也降低了。
a = [1 , 2 , 3 ]
b = [1 , 2 , 3 ]
print(id(a))
print(id(b))
print(a is b)
print(a == b)
python中有常量池,会把常用的整数对象和字符串对象都缓冲起来,在此范围内的对象如果值相同,指向的都会是同一个对象。
a = 21
b = 21
print(a is b)
a = "python3.7"
b = "python3.7"
print(a is b)
对于整数,python全局解释器仅对[-5, 256]范围内的整数进行了缓冲,超过此范围的整数得到的结果依然会是False
。但这仅是在命令行中执行得到的结果,如果在Pycharm或保存为文件执行,就没有这个范围的限制,因为解释器做了一部分优化
命令行
>>> a = -6
>>> b = -6
>>> a is b
False
>>> a = 257
>>> b = 257
>>> a is b
False
保存为文件执行
a = -6
b = -6
print(a is b)
a = 257
b = 257
print(a is b)