python__radd__原理?

关注者
1
被浏览
2,954
登录后你可以
不限量看优质回答私信答主深度交流精彩内容一键收藏

分为两个问题

1. 题目描述中的代码问题 ("1-s"实际是如何执行的)

1 - s 可以看作 1 - A(2)

对象A未实现__rsub__方法,则会调用父类(int)的__rsub__方法,然后返回。

2. python__radd__原理?

简单来讲就是+操作符的重载,用于用户自定义实例间使用 + 操作符的操作

Python在执行 + 操作的时候,例如 执行 a + b时

如果 a 有 __add__ 方法, 而且返回值不是 NotImplemented, 调用a.__add__(b), 然后返回结果。

如果 a 没有 __add__ 方法, 或者调用 __add__ 方法返回NotImplemented, 检查 b 有没有 __radd__ 方法, 如果有, 而且没有返回 NotImplemented, 调用 b.__radd__(a), 然后返回结果。

如果 b 没有 __radd__ 方法, 或者调用 __radd__ 方法返回NotImplemented, 抛出 TypeError, 并在错误消息中指明操作数类型不支持。