未命名的Python对象具有相同的id

未命名的Python对象具有相同的id,python,python-2.7,Python,Python 2.7,让我们创建两个列表: x = range(3) y = range(3) print id(x), id(y) 输出: 我创建了两个独立的列表,输出显示了两个不同的内存地址。这并不奇怪。但是现在让我们在没有作业的情况下做同样的事情: id(range(3)) id(range(3)) 输出: 第二次: 输出: 我不知道该如何解释这一点。为什么这两个未命名的列表具有相同的内存地址?: 返回对象的“标识”。这是一个整数,保证该对象在其生存期内唯一且恒定两个生命周期不重叠的对象可能具有相同的id

让我们创建两个列表:

x = range(3)
y = range(3)
print id(x), id(y)
输出:

我创建了两个独立的列表,输出显示了两个不同的内存地址。这并不奇怪。但是现在让我们在没有作业的情况下做同样的事情:

id(range(3))
id(range(3))
输出:

第二次:

输出:

我不知道该如何解释这一点。为什么这两个未命名的列表具有相同的内存地址?


返回对象的“标识”。这是一个整数,保证该对象在其生存期内唯一且恒定两个生命周期不重叠的对象可能具有相同的id()值。

由于
id()
调用中的两个范围具有不重叠的生存期,因此它们的id值可能相同

分配给变量的两个范围具有重叠的生存期,因此它们必须具有不同的id值

编辑:

查看C源代码可以发现:

还有

PyLong_from void ptr(void*p)
{

#如果SIZEOF_VOID_P

在创建第二个对象时,第一个对象已超出范围


我不知道python是否有点聪明,是否意识到第二个对象与第一个对象完全相同(现已超出范围),并简单地对其重复使用相同的地址?

“两个生命周期不重叠的对象可能具有相同的id()值”稍微相关:可能重复
4366623376
id(range(3))
4366623376
builtin_id(PyObject *self, PyObject *v)
{
    return PyLong_FromVoidPtr(v);
}
PyLong_FromVoidPtr(void *p)
{
#if SIZEOF_VOID_P <= SIZEOF_LONG
    return PyLong_FromUnsignedLong((unsigned long)(Py_uintptr_t)p);
#else

#ifndef HAVE_LONG_LONG
#   error "PyLong_FromVoidPtr: sizeof(void*) > sizeof(long), but no long long"
#endif
#if SIZEOF_LONG_LONG < SIZEOF_VOID_P
#   error "PyLong_FromVoidPtr: sizeof(PY_LONG_LONG) < sizeof(void*)"
#endif
    return PyLong_FromUnsignedLongLong((unsigned PY_LONG_LONG)(Py_uintptr_t)p);
#endif /* SIZEOF_VOID_P <= SIZEOF_LONG */

}