'super'对象未调用__getattr__

'super'对象未调用__getattr__,第1张

'super'对象调用__getattr__

据此,
super不允许隐式调用诸如的“
hook”函数

__getattr__
。我不确定为什么要用这种方式实现(这可能是一个很好的理由,并且由于超级对象具有自定义
__getattribute__
__get__
方法,所以事情已经很混乱了),但似乎事情就是这样。

编辑:这篇文章似乎清除了一些东西。看起来问题在于,

__getattribute__
隐式调用函数时,由引起的额外的间接层将被忽略。做
foo.x
等同于

foo.__getattr__(x)

(假设

__getattribute__
未定义任何方法,并且x不在in
foo.__dict__
)但是,它不等于

foo.__getattribute__('__getattr__')(x)

由于super返回一个代理对象,因此它具有一个额外的间接层,这会导致事务失败。

PS完全不需要

self.__dict__
检查
__getattr__
功能。
__getattr__
仅当字典中不存在该属性时才调用。(
__getattribute__
如果您希望始终调用它,则可以使用它,但是您必须非常小心,因为即使是简单的东西
ifname in self.__dict__
也会导致无限递归



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5647150.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存