在python中is 与 == 都是用来对两个值用来做比较判断,但是对对象判断比较的内容不同:
- is 运算符是用来检查两个运算对象是否引用至同一对象(即:它检查两个预算对象是否相同)。
- ==运算符比较两个运算对象的值师傅相等
因此:is 代表引用相同, == 代表值相等,可以通过下面的例子来说明:
>>> [] == []
True
>>> [] is [] # 这两个空列表位于不同的内存地址
False
网上之前很有名的一个例子:
>>> a = 256
>>> b = 256
>>> a is b
True
>>> a = 257
>>> b = 257
>>> a is b
False
>>> a = 257; b = 257
>>> a is b
True
256 是一个已经存在的对象,而257 不是
当启动python时,-5到256 的数值就已经被分配好,这些数值因为经常使用所以适合被提前准备好。可以参照说明文档https://docs.python.org/3/c-api/long.html
>>> id(256)
507089376
>>> a = 256
>>> b = 256
>>> id(a)
507089376
>>> id(b)
507089376
>>> id(257)
35358544
>>> x = 257
>>> y = 257
>>> id(x)
35358544
>>> id(y)
43274128
>>>
当执行y=257时,解释器没有意识到已经创建了一个整数257,所以它在内存中又新建了一个对象。
当a 和b在同一行使用相同的值初始化的时候,会指向同一个对象。
>>> a, b = 257, 257
>>> id(a)
34153840
>>> id(b)
34153840
>>> a = 257
>>> b = 257
>>> id(a)
35358544
>>> id(b)
43274160
- 当a 和b 在同一行被设置为257时,python解释器会创建一个新对象,然后同时引用第二个变量,如果你在不同的行上进行,它就不会知道已经存在一个257对象。
- 这是一种特别为交互式环境做的编译器优化。当你在实时解释器中输入两行的时候,他们会单独编译,因此会单独进行优化。如果你在.py文件中尝试这个例子,则不会看到相同的行为,因为文件是一次性编辑的。