
id,并且事实上,对于您单独定义的任何类型的对象,这都是不正确的。一般来说,每次在Python中定义对象时,都会创建一个具有新标识的新对象。但是,出于优化的目的(通常),小整数(介于-5和256之间)和具有特殊长度(通常少于20个字符)的内联字符串也有一些例外,*是单例并且具有相同的
id(实际上是一个具有多个指针的对象)。您可以像下面这样检查:
>>> 30 is (20 + 10)True>>> 300 is (200 + 100)False>>> 'aa' * 2 is 'a' * 4True>>> 'aa' * 20 is 'a' * 40False
对于自定义对象:
>>> class A:... pass... >>> A() is A() # Every time you create an instance you'll have a new instance with new identityFalse
还要注意,
is*** 作员将检查对象的身份,而不是值。如果要检查值,请使用
==:
>>> 300 == 3*100True
而且由于没有针对元组或任何可变类型的优化或内部规则,因此,如果您定义任何大小的两个相同的元组,它们将具有自己的标识,因此对象也不同:
>>> a = (1,)>>> b = (1,)>>>>>> a is bFalse
还值得一提的是,即使在迭代器中定义了“单整数”和“内部字符串”的规则,它们也是正确的。
>>> a = (100, 700, 400)>>>>>> b = (100, 700, 400)>>>>>> a[0] is b[0]True>>> a[1] is b[1]False
*一篇很好的详细文章:http : //guilload.com/python-string-interning/
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)