当前位置: 首页 > news >正文

Python 属性描述符(描述符用法建议)

描述符用法建议

下面根据刚刚论述的描述符特征给出一些实用的结论。
使用特性以保持简单
内置的 property 类创建的其实是覆盖型描述符,__set__ 方法和
__get__ 方法都实现了,即便不定义设值方法也是如此。特性的
__set__ 方法默认抛出 AttributeError: can’t set attribute,
因此创建只读属性最简单的方式是使用特性,这能避免下一条所述的问
题。

只读描述符必须有__set__方法
如果使用描述符类实现只读属性,要记住,__get____set__
两个方法必须都定义,否则,实例的同名属性会遮盖描述符。只读属性
__set__ 方法只需抛出 AttributeError 异常,并提供合适的错误
消息。

用于验证的描述符可以只有 __set__ 方法
对仅用于验证的描述符来说,__set__ 方法应该检查 value 参数
获得的值,如果有效,使用描述符实例的名称为键,直接在实例的
__dict__ 属性中设置。这样,从实例中读取同名属性的速度很快,因
为不用经过 __get__ 方法处理。参见示例 20-1 中的代码。

仅有 __get__ 方法的描述符可以实现高效缓存
如果只编写了 __get__ 方法,那么创建的是非覆盖型描述符。这
种描述符可用于执行某些耗费资源的计算,然后为实例设置同名属性,
缓存结果。同名实例属性会遮盖描述符,因此后续访问会直接从实例的__dict__ 属性中获取值,而不会再触发描述符的 __get__ 方法。

非特殊的方法可以被实例属性遮盖

由于函数和方法只实现了 __get__ 方法,它们不会处理同名实例
属性的赋值操作。因此,像 my_obj.the_method = 7 这样简单赋值之
后,后续通过该实例访问 the_method 得到的是数字 7——但是不影响
类或其他实例。然而,特殊方法不受这个问题的影响。解释器只会在类
中寻找特殊的方法,也就是说,repr(x) 执行的其实是
x.__class__.__repr__(x),因此 x 的__repr__属性对 repr(x) 方
法调用没有影响。出于同样的原因,实例的 __getattr__ 属性不会破
坏常规的属性访问规则。

实例的非特殊方法可以被轻松地覆盖,这听起来不可靠且容易出错,可
是在我使用 Python 的 15 年中从未受此困扰。然而,如果要创建大量动
态属性,属性名称从不受自己控制的数据中获取(像本章前面那样),
那么你应该知道这种行为;或许你还可以实现某种机制,过滤或转义动
态属性的名称,以维持数据的健全性。

示例 19-6 中的 FrozenJSON 类不会出现实例属性遮盖方法的
问题,因为那个类只有几个特殊方法和一个 build 类方法。只要
通过类访问,类方法就是安全的,在示例 19-6 中我就是这么调用
FrozenJSON.build 方法的——在示例 19-7 中替换成 __new__
法了。Record 类(见示例 19-9 和示例 19-11)及其子类也是安全
的,因为只用到了特殊的方法、类方法、静态方法和特性。特性是
数据描述符,因此不能被实例属性覆盖。

讨论特性时讲了两个功能,这里讨论的描述符还未涉及,结束本章之前
我们来讲讲:文档和对删除托管属性的处理。

http://www.xdnf.cn/news/1268281.html

相关文章:

  • 词向量可视化:用TensorBoard或PCA探索词向量空间
  • RecyclerView 中 ViewHolder
  • Datawhale+AI夏令营_让AI读懂财报PDF task2深入赛题笔记
  • 学习Java的Day28
  • 常用信号深度解析(SIGINT、SIGPIPE、SIGALRM、SIGTERM等)
  • Android 锁屏图标的大小修改
  • 线上排查问题的一般流程是怎么样的?
  • [激光原理与应用-207]:光学器件 - 光纤种子源激光器常用元器件
  • python---类型别名
  • 新手小白使用jQuery在实际开发中常用到的经验
  • ABP VNext + Akka.NET:高并发处理与分布式计算
  • 从 AI 到实时视频通道:基于模块化架构的低延迟直播全链路实践
  • Vuex与Pinia对比,以及技术选型
  • 《C++进阶之继承多态》【普通类/模板类的继承 + 父类子类的转换 + 继承的作用域 + 子类的默认成员函数】
  • 10.final, finally, finalize的区别
  • 【自动化运维神器Ansible】playbook自动化部署Nginx案例解析:助力从零构建高效Web服务
  • 2025 大语言模型系统学习路线:从基础到部署与优化的全方位指南(含权威资源与项目实战)
  • 4深度学习Pytorch-神经网络--损失函数(sigmoid、Tanh、ReLU、LReLu、softmax)
  • IDEA快捷键壁纸分享
  • 光伏面板损伤检出率↑91%!陌讯多模态识别算法在无人机巡检的落地实践
  • AI 破解数据质量难题:从混乱到可信的智能进化之路
  • 计算机网络1-6:计算机网络体系结构
  • webwork的学习
  • 非常简单!从零学习如何免费制作一个lofi视频
  • 香橙派 RK3588 部署千问大模型 Qwen2-VL-2B 推理视频
  • 2025华数杯数学建模C题:可调控生物节律LED光源全解析
  • 2025华数杯B题一等奖方案:网络切片无线资源管理全解析(附Python/MATLAB代码)
  • 机器学习(西瓜书)学习——绪论
  • LeetCode 面试经典 150_数组/字符串_分发糖果(15_135_C++_困难)(贪心算法)
  • 【Redis7.x】docker配置主从+sentinel监控遇到的问题与解决