语句发生了几件事
x=5:
5
创建了一个值为的int对象(或找到它是否已经存在);- 名称
x
已创建(或与最后标记的对象“ x”无关); - 对新的(或找到的)int对象的引用计数增加1;
- 该名称
x
与创建(或找到)值为“ 5”的对象相关联。
由于int对象是不可变的,因此可以为效率而对它们进行实习。字符串对象更有可能被阻止。
这里有些例子:
>>> x=5 # discussed>>> id(x) # the 'id' which in cPython is the memory address.140246146681256>>> y=x # now two names, 'x' and 'y' associated with that object>>> id(y) 140246146681256 # same object>>> z=5 # no guaranteed, likely the same object referred to by 'x' and 'y'>>> id(z)140246146681256 # id is the same! The object labeled 'x' was found and labeled 'z'>>> del x# ref count to object '140246146681256' decreased by 1>>> del y# same>>> z5>>> id(z)140246146681256 # same object but the names ''x' and 'y' no longer label it
想到变量名称(如“ x”)的最佳方法
x=5是作为标签。
可能有没有标签的对象,例如在此列表理解中创建的5个单独的字符串对象:
>>> li=[str(x) for x in range(5)] >>> li['0', '1', '2', '3', '4']
然后,您可以创建与这些5个对象的值分别匹配的对象:
>>> li2=list('012345') # longer list; completely different construction>>> li2['0', '1', '2', '3', '4', '5']您可以获取它们各自的内存地址(在cPython中)或唯一的ID地址:
>>> [id(x) for x in li][4373138488, 4372558792, 4372696960, 4373139288, 4373139368]>>> [id(x) for x in li2][4373138488, 4372558792, 4372696960, 4373139288, 4373139368, 4372696720]
请注意,两个独立创建的匿名对象列表是相同的(在本例中为前5个)。我故意使用字符串,因为它们更有可能被插入…
因此,请这样考虑:两个不同的过程正在发生
x=5:
- 对象被创建(或被发现是否是不可变的,被检查的并存在),并且
- 该对象被标记。



