对于运算符,Python定义了一个对象可以实现的三个“特殊”方法:
> __add__:添加两个项目(运算符).当你做一个b时,a的__add__方法用b作为参数来调用.
> __radd__:reflect add;对于b,b的__radd__方法作为一个实例被调用.这仅在不知道如何做添加和两个对象是不同类型时才使用.
> __iadd__:就地添加用于a = b,其中结果被分配回到左侧变量.这是单独提供的,因为可能以更有效的方式实施它.例如,如果a是列表,那么a = b与a.extend(b)相同.但是,在c = a b的情况下,必须在扩展之前复制一个副本,因为在这种情况下不要修改.请注意,如果您不实现__iadd__,则Python将仅调用__add__.
因此,由于这些不同的操作是通过单独的方法实现的,所以实现它们是可能的(但通常是不好的做法),所以它们完全不同,或者也许在这种情况下,只有稍微不同的东西.
其他人推断你正在使用NumPy并解释其行为.但是,您询问了底层实现.希望你现在可以看到为什么有时候a = b与a = a b不一样.顺便说一下,也可以为其他操作实现类似的三重方法.有关所有支持的就地方法的列表,请参阅this page.