news 2026/2/6 11:39:36

Python:实例 __dict__ 详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Python:实例 __dict__ 详解

在 Python 的对象模型中,实例的属性并不是直接存在于对象内部的字段,而是统一存放在一个名为 __dict__ 的映射结构中。

理解实例 __dict__,本质上是在理解实例属性从何而来、属性如何被创建、查找与销毁以及实例命名空间的生命周期与作用边界。

一、实例 __dict__ 的定义与本质

实例 __dict__ 是一个字典对象,用于存储实例对象的“实例级属性”。

class A: pass a = A()a.x = 10 print(a.__dict__) # {'x': 10}type(a.__dict__) # <class 'dict'>

说明:

• a.__dict__ 是实例命名空间(Instance Namespace)。

• 键是属性名(字符串),值是对应的属性值。

每个实例都有自己独立的 __dict__。因此:

a1 = A()a2 = A() a1.x = 1a2.x = 2 print(a1.__dict__) # {'x': 1}print(a2.__dict__) # {'x': 2}

实例之间不会共享 __dict__。

二、实例属性的创建机制:写入即绑定

实例属性并不需要提前声明。任何对实例属性的赋值操作,都会直接写入实例的 __dict__。

a.y = 20

等价于:

a.__dict__['y'] = 20

这说明,Python 中实例属性是运行期动态绑定的。实例 __dict__ 是属性创建的唯一存储位置(不考虑 __slots__ 时)。

删除属性时同理:

del a.y# 等价于del a.__dict__['y']

三、实例 __dict__ 在属性查找中的位置

当访问 a.attr 时,Python 使用以下固定顺序进行查找(简化版):

1、实例 a.__dict__

2、类 A.__dict__

3、父类的 __dict__(按 MRO 顺序)

4、若仍未找到,触发 __getattr__()

因此,实例 __dict__ 具有非常高的优先级。

示例:

class A: x = 100 # 类属性 a = A()a.x = 10 # 实例属性 print(a.x) # 10print(A.x) # 100

原因是:

a.__dict__ == {'x': 10}

实例属性会遮蔽(shadow)同名类属性。

四、实例 __dict__ 的生命周期

实例 __dict__ 的生命周期与实例对象完全一致。

1、创建时

a = A()

此时:

a.__dict__ == {}

实例创建完成后即拥有一个空的 __dict__。

2、使用期间

随着属性赋值、修改、删除,实例 __dict__ 持续变化:

a.x = 1a.y = 2del a.x

3、销毁时

当实例对象被垃圾回收:

del a

实例 __dict__ 随实例一并销毁,不会留下任何“残余属性”。

因此,实例 __dict__ 不具备跨实例、跨生命周期的持久性。

五、实例 __dict__ 与方法、描述符的关系

1、实例方法不存放在实例 __dict__

class A: def f(self): pass a = A()'a.f' in a.__dict__ # False

说明:

方法定义在类体内,存放于类 __dict__(此处为 A.__dict__)中,通过描述符机制动态绑定。

2、数据描述符优先级高于实例 __dict__

对于数据描述符(比如 property):

class A: @property def x(self): return 42 a = A()a.__dict__['x'] = 100 a.x # 42

说明:

数据描述符优先于实例 __dict__,但非数据描述符优先级要低于实例 __dict__。

六、实例 __dict__ 与 __slots__ 的限制关系

如果类定义了 __slots__:

class A: __slots__ = ('x',) a = A()a.x = 1

此时:

hasattr(a, '__dict__') # False(默认)

说明:

__slots__ 会移除实例 __dict__,实例属性改为使用静态结构存储,从根本上改变了实例命名空间模型。

若要显式保留:

class A: __slots__ = ('x', '__dict__')

七、常见误解与澄清

误解 1:实例属性存放在类中

❌ 错误

✔ 正解:实例属性只存放在实例 __dict__ 中。

误解 2:实例 __dict__ 与类 __dict__ 是同一个

❌ 错误

✔ 正解:它们是完全不同的命名空间。

误解 3:方法属于实例

❌ 错误

✔ 正解:方法属于类,通过描述符机制绑定实例。

误解 4:删除实例不会影响类属性

✔ 正确

实例 __dict__ 的生命周期与类完全无关。

📘 小结

实例 __dict__ 是实例级命名空间,用于存储对象在运行期动态绑定的属性。它以字典形式存在,生命周期与实例一致,在属性查找顺序中通常优先于类 __dict__。实例属性的赋值、修改与删除本质上都是对实例 __dict__ 的操作。方法不存放在实例 __dict__ 中,而是定义在类中并通过描述符机制动态绑定。

理解实例 __dict__ 有助于掌握 Python 的属性模型、命名空间体系与对象生命周期管理。

“点赞有美意,赞赏是鼓励”

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/5 12:38:08

GPT-SoVITS能否实现语音紧张感合成?心理实验应用

GPT-SoVITS能否实现语音紧张感合成&#xff1f;心理实验应用 在一场模拟高压决策的心理学实验中&#xff0c;研究人员需要向被试播放一段“带有紧张情绪的语音提示”——比如&#xff1a;“时间只剩10秒&#xff0c;你必须立刻做出选择。”传统做法是使用演员录制好的音频。但问…

作者头像 李华
网站建设 2026/2/4 19:59:06

基于python的公益活动报名志愿者服务平台的设计与实现_pycharm django vue flask

目录已开发项目效果实现截图开发技术路线相关技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;已开发项目效果实现截图 同行可拿货,招校园代理 基于python的公益活动报名志愿者服务平台的设计与实现_pychar…

作者头像 李华
网站建设 2026/2/5 20:17:32

14、机器学习助力客户分析:倾向、流失与细分模型构建

机器学习助力客户分析:倾向、流失与细分模型构建 1. 构建客户购买倾向模型 在使用 Microsoft Azure 机器学习服务构建买家倾向模型时,有一套实用的操作流程。首先,要对数据进行预处理和分析,这是理解用于构建客户倾向模型数据的关键步骤。只有对数据有了清晰的理解,才能…

作者头像 李华
网站建设 2026/2/3 12:51:50

GPT-SoVITS语音合成在自动售货机交互中的应用

GPT-SoVITS语音合成在自动售货机交互中的应用 在城市地铁站、写字楼走廊或校园角落&#xff0c;一台自动售货机发出温柔的女声&#xff1a;“欢迎回来&#xff0c;小王&#xff01;今天要来瓶冰镇可乐吗&#xff1f;”——这不再是科幻电影的情节。随着边缘计算与AI语音技术的…

作者头像 李华
网站建设 2026/2/5 13:12:07

SWD-119-PIN,转换TTL信号为GaAs FET控制电压的四通道驱动器, 现货库存

型号介绍今天我要向大家介绍的是 MACOM 的一款驱动器——SWD-119-PIN。 它的传播延迟时间在 22ns 到 30ns 之间&#xff0c;输出上升和下降时间分别约为 9ns 和 8ns&#xff0c;能够满足快速响应的要求。芯片采用塑料 SOIC-16 封装形式&#xff0c;具有成本低、占用空间小的特…

作者头像 李华
网站建设 2026/2/3 11:55:33

Keil5安装教程:手把手教你配置嵌入式开发环境

手把手搭建Keil5嵌入式开发环境&#xff1a;从零开始的实战指南 你是不是也曾在准备STM32项目时&#xff0c;卡在了第一步—— Keil5装不上、打不开、下不了程序 &#xff1f; 官网下载慢得像蜗牛&#xff0c;注册机不敢用怕中毒&#xff0c;芯片选了半天却提示“not found…

作者头像 李华