让我们创建两个列表:
x = range(3)
y = range(3)
print id(x), id(y)
Run Code Online (Sandbox Code Playgroud)
日期:
4366592912 4366591040
Run Code Online (Sandbox Code Playgroud)
我创建了两个独立的列表,输出显示了两个不同的内存地址.这并不奇怪.但现在让我们在没有任务的情况下做同样的事情:
id(range(3))
Run Code Online (Sandbox Code Playgroud)
日期:
4366623376
Run Code Online (Sandbox Code Playgroud)
第二次:
id(range(3))
Run Code Online (Sandbox Code Playgroud)
日期:
4366623376
Run Code Online (Sandbox Code Playgroud)
我不知道如何解释这一点.为什么这两个未命名的列表具有相同的内存地址?
小智 13
返回对象的"标识".这是一个整数,在该生命周期内保证该对象是唯一且恒定的.具有非重叠生存期的两个对象可以具有相同的id()值.
由于id()调用内的两个范围具有非重叠的生命周期,因此它们的id值可能相同.
分配给变量的两个范围具有重叠的生命周期,因此它们必须具有不同的id值.
编辑:
查看C源代码向我们展示builtin_id:
builtin_id(PyObject *self, PyObject *v)
{
return PyLong_FromVoidPtr(v);
}
Run Code Online (Sandbox Code Playgroud)
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 */
}
Run Code Online (Sandbox Code Playgroud)
所以ID是一个内存地址.
| 归档时间: |
|
| 查看次数: |
694 次 |
| 最近记录: |