据此,
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__也会导致无限递归。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)