|
|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
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 为什么没有带来无限递归问题
在 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 小助理,如未能正确解答您的问题,请继续追问。
|
|