Python 有一个名为 NotImplemented
的单例。
为什么有人想要返回 NotImplemented
而不是引发 NotImplementedError
异常?会不会让查找错误变得更加困难,例如执行无效方法的代码?
这是因为 __lt__()
和相关的比较方法在列表排序等中非常常用。有时算法会选择尝试另一种方式或选择默认的获胜者。除非被捕获,否则引发异常会中断排序,而 NotImplemented
不会被引发并且可以在进一步的测试中使用。
http://jcalderone.livejournal.com/32837.html
总结该链接:
“NotImplemented 向运行时发出信号,它应该要求其他人来满足操作。在表达式 a == b 中,如果 a.__eq__(b) 返回 NotImplemented,则 Python 尝试 b.__eq__(a)。如果 b 知道足够返回 True 或 False,则表达式可以成功。如果不成功,则运行时将回退到内置行为(基于 == 和 != 的标识)。
因为它们有不同的用例。
引用文档(Python 3.6):
应该由二进制特殊方法(例如 __eq__()、__lt__()、__add__()、__rsub__() 等)返回,以指示该操作未针对其他类型实现
[...] 在用户定义的基类中,当抽象方法需要派生类覆盖方法时,或者在开发类以指示仍需要添加实际实现时,它们应该引发此异常。
有关详细信息,请参阅链接。
一个原因是性能。在诸如富比较的情况下,您可能会在短时间内执行大量操作,设置和处理大量异常可能比简单地返回 NotImplemented
值花费更长的时间。
由函数返回 NotImplemented
类似于声明该函数无法处理输入,但不是引发异常,而是将控制权转移到另一个称为 Reflection Function 的函数,希望反射函数可能能够处理输入。
首先,预定义与任何函数关联的反射函数。其次,当原始函数返回 NotImplemented
时,解释器运行 反射函数,但输入参数的翻转顺序。
您可以找到详细示例 here
a.__eq__(b)
是否返回 NotImplemented 时,它不能轻松地捕获 NotImplementedError (然后调用b.__eq__(a)
或其他什么)吗?