为了账号安全,请及时绑定邮箱和手机立即绑定

在 Python 中遇到意外的类行为

在 Python 中遇到意外的类行为

慕村9548890 2022-12-06 17:29:39
我运行了下面的代码;class A:    def __init__(self):        self.f = 1    def __add__(self, x):        self.f += x        return self    def __radd__(self, x):        self.f += x        return self>>> a = A()>>> a + 2<__main__.A object at 0x7f96a90d5700>>>> a.f == 3True# as expected, so far>>> a = A()>>> b = A()>>> a + b<__main__.A object at 0x7f3d86d7c700>>>> a.f<__main__.A object at 0x7f3d86d7cb80>>>> b.f2>>> a.f.f2>>> a.f is bTrue刚才发生了什么?为什么是a.f == b和b.f == 2。我想知道这是否是某种明确的行为,我没有正确解释。
查看完整描述

1 回答

?
犯罪嫌疑人X

TA贡献2080条经验 获得超4个赞

  1. 该线路在 上a + b呼叫__add__接线员a

  2. +=不起作用 ( ) 并因此int + A调用__radd__on b

  3. 在这里,b.f接收值2并将自身作为对象返回。

  4. 然后将此对象分配给a.f.

所以一切都符合预期,除了非常不寻常的编码方式。我希望您编写的代码不会伤害到任何人。

即使您坚持自己的编码,让我(至少对于其他读者)建议定义这些运算符的正常方法:

def __add__(self, x):

    result = A()

    try:

        result.f = self.f + x.f

    except AttributeError:

        result.f = self.f + x

    return result


def __radd__(self, x):

    result = A()

    try:

        result.f = self.f + x.f

    except AttributeError:

        result.f = self.f + x

    return result

现在你可以计算a+b,2+a等等a+2。


查看完整回答
反对 回复 2022-12-06
  • 1 回答
  • 0 关注
  • 117 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信