Python运行时环境的核心是内存管理与对象模型协同工作,一切皆对象,含类型、引用计数和值三部分;引用计数主导自动回收,循环引用需gc模块辅助;小整数和短字符串被池化复用;id()、is、==分别标识地址、同一性与逻辑相等。
Python运行时环境的核心是内存管理与对象模型的协同工作——代码执行时,所有变量、函数、类都不是直接操作内存地址,而是通过对象引用和引用计数机制间接管理。
Python中一切皆对象,每个对象在内存中包含三部分:类型信息(type)、引用计数(refcount)、实际值(value)。例如执行 x = 123,解释器会创建一个整型对象,其类型为 int,引用计数初始为1,值存储在对象数据区。该对象被分配在堆内存中,而变量 x 本身只是栈上一个指向该对象的指针(即引用)。
Python主要依赖引用计数实现自动内存管理。每当一个对象被赋值、作为参数传入函数、加入容器等,其引用计数加1;当变量重新赋值、离开作用域或显式删除(del x),计数减1。一旦计数归零,对象立即被释放。
为提升性能,CPython对常用小整数(-5 到 256)和短字符串做了对象池(interning)优化。这些对象在解释器启动时预先创建并复用:
id() 返回对象在内存中的唯一标识(CPython中近似为地址);is 判断两个变量是
否指向同一对象(即 id(a) == id(b));== 调用对象的 __eq__ 方法,判断逻辑相等性。