id()返回对象唯一标识符,在CPython中对应内存地址,用于判断变量是否引用同一对象,理解引用机制与可变性差异。

在 Python 中,id() 函数返回的是对象的唯一标识符,通常被认为是该对象在内存中的地址。这个标识符在整个对象生命周期内保持不变。
id() 的本质
Python 中每个对象都有一个唯一的 id。虽然它“通常”对应于对象在内存中的位置,但具体实现由解释器决定。在 CPython(最常用的 Python 实现)中,id() 返回的确实是对象的内存地址。
例如:
print(id(100)) # 输出类似 140723456789016a = [1, 2, 3]
print(id(a)) # 输出列表 a 的“地址”
id() 与变量的关系
变量本身不具有 id,它们只是对对象的引用。多个变量可以指向同一个对象,因此它们的 id 相同:
立即学习“Python免费学习笔记(深入)”;
x = [1, 2, 3]y = x
print(id(x) == id(y)) # True:x 和 y 指向同一对象
可变与不可变对象的行为差异
对于不可变对象(如整数、字符串、元组),Python 可能会重用对象以节省内存(称为“对象缓存”或“驻留”):
a = 256b = 256
print(id(a) == id(b)) # 通常为 True(小整数被缓存)
a = 257
b = 257
print(id(a) == id(b)) # 不一定为 True,取决于解释器优化
而可变对象每次创建都会分配新的 id:
print(id([1, 2]) == id([1, 2])) # False:两个不同的列表对象实际用途与注意事项
使用 id() 主要用于:
- 调试时判断两个变量是否引用同一对象
- 理解 Python 的引用机制和可变性问题
- 避免意外的共享状态(特别是在可变对象上)
注意:不要依赖 id() 的具体数值做逻辑判断,只应比较两个 id 是否相等,来判断是否为同一对象。
基本上就这些。id() 提供了观察 Python 对象模型的窗口,理解它有助于写出更安全的代码。










