Python 类方法的特殊处理:为什么调用 __getattr__ 却直接执行方法?
python 类方法的特殊处理
在 python 中,我们可以通过 __getattr__ 方法拦截类的属性获取操作。然而,当该属性存在于类的基类或子类中时,可能会出现不符合预期的情况。
问题:调用 __getattr__ 却直接执行方法
在所提供的示例中,pointer 类定义了 __getattr__ 方法,用于拦截对 __value 属性的访问。然而,在调用 s.__str__ 时,它却直接执行了 str 类的 __str__ 方法,而没有经过 pointer 类的 __getattr__ 方法。
立即学习“Python免费学习笔记(深入)”;
解决方法:定义一个 __str__ 方法
为了解决这个问题,可以在 pointer 类中直接定义一个 __str__ 方法。当调用 s.__str__ 时,python 将直接使用 pointer 类中的 __str__ 方法,而不是通过 str(s) 转换后再调用 str 类的 __str__ 方法。
修改后的代码如下:
class Pointer: ... def __str__(self): return str(self.__value)
通过这种方式,s.__str__ 将调用 pointer 类中的 __str__ 方法,从而使用 pointer 类的 __getattr__ 方法拦截对 __value 属性的访问。