返回介绍

第一个示例

发布于 2024-01-29 22:24:14 字数 1065 浏览 0 评论 0 收藏 0

所有这些并不像我们前一小节所暗示的那样复杂。要看看如何把这些思想付诸应用,这里是与用来说明特性和描述符的示例一样的示例,不过这次是用属性操作符重载方法实现的。由于这些方法如此通用,所以我们在这里测试属性名来获知何时将要访问一个管理的属性;其他的则允许正常传递:

注意,__init__构造函数中的属性赋值也触发了__setattr__,这个方法捕获了每次属性赋值,即便是类自身之中的那些。运行这段代码的时候,会产生同样的输出,但这一次,它是Python的常规操作符重载机制与我们的属性拦截方法的结果:

还要注意,与特性和描述符不同,这里没有为属性直接声明指定的文档,管理的属性存在于我们拦截方法的代码之中,而不是在不同的对象中。

要实现与__getattribute__相同的结果,用下面的代码替换示例中的__getattr__,由于它会捕获所有的属性获取,这个版本必须通过把新的获取传递到超类来避免循环,并且通常不能假设未知的名称是错误:

这个例子与我们为属性和描述符编写的代码相同,但是它有点人为的痕迹,并且它没有真正地强调这些工具的应用。由于它们是通用的,所以__getattr__和__getattribute__可能在基于委托的代码中更为常用(正如前面所介绍的),在那里属性访问验证并指向一个嵌入的对象。在只有单个的属性要管理的情况下,特性和描述符可能会做得更好。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文