yanghp 发表于 2025-11-27 14:13:48

__getattr__()方法问题

class D:
    def __init__(self):
      self._x = 250
    def __getattr__(self,name):
      if name == 'x':
            return self._x
      else:
            super().__getattr__(name)
    def __setattr__(self,name,value):
      if name == 'x':
            super().__setattr__('_x',value)
      else:
            super().__setattr__(name,value)
    def __delattr__(self,name):
      if name == 'x':
            super().__delattr__('_x')
      else:
            super().__delattr__(name)

请问, def __getattr__(self,name):
      if name == 'x':
            return self._x
return self._x 为什么没有带来无限递归问题

FishC 发表于 2025-11-27 14:14:53

在 Python 中,__getattr__ 方法仅在属性查找失败时被调用(即属性不在实例字典、类字典或继承链中时)。在您的代码中,当访问属性 x 时,__getattr__ 被触发,并执行 return self._x。

这里没有无限递归的原因是:_x 是一个已存在的属性(在 __init__ 中通过 self._x = 250 设置),因此访问 self._x 时不会再次触发 __getattr__ 方法。Python 会直接从实例字典中获取 _x 的值,避免了递归调用。

相反,如果代码中使用了 return self.x,则会无限递归,因为每次访问 x 都会重新触发 __getattr__。

注意:您的代码中 else 分支的 super().__getattr__(name) 可能抛出 AttributeError,因为基类 object 没有定义 __getattr__ 方法。如果需要处理不存在的属性,建议改为抛出 AttributeError 或使用其他逻辑。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
页: [1]
查看完整版本: __getattr__()方法问题