无限递归死循环
class D:def __setattr__(self,name,value):
self.name = value
d = D()
d.name = "额"
为什么这段代码是无限递归啊?帮忙解释一下。谢谢。 这段代码会导致无限递归的原因是在类D的 __setattr__ 方法中,当给 self.name 赋值时,会再次调用 __setattr__ 方法,从而导致无限递归。
具体来说,在 d.name = "额" 这行代码中,Python会调用 d 对象的 __setattr__ 方法来设置属性 name 的值。而在 __setattr__ 方法中,通过 self.name = value 语句将属性 name 的值设置为 value 。然而,这个赋值操作实际上会再次调用 __setattr__ 方法,因为在赋值操作中,Python会尝试设置 self.name 属性的值,而 self.name 又是 self 对象的属性,所以会再次调用 __setattr__ 方法,形成了递归调用。
为了避免无限递归,可以在 __setattr__ 方法中使用 super().__setattr__(name, value) 来调用父类的 __setattr__ 方法,而不是直接使用 self.name = value 。这样可以避免直接调用 __setattr__ 方法,从而解决无限递归的问题。
修正后的代码如下:
class D:
def __setattr__(self, name, value):
super().__setattr__(name, value)
d = D()
d.name = "额"
这样修改后,赋值操作不会再次调用 __setattr__ 方法,从而避免了无限递归。 因为 self.name = value 同样会触发自身的 __setattr__() 魔法方法。
页:
[1]