Python中基类object提供了一系列可以用于实现同类对象进行“比较”的方法,可以用于同类对象的不同实例进行比较,包括__lt__、__gt__、__le__、__ge__、__eq__和__ne__
六个方法。
那么为什么叫“富比较”(“rich comparison”)方法呢?查了相关资料,并没有看到权威的定义,老猿结合网上零星的资料,分析原因如下:
- Python2.1以前的比较方法只提供一个__cmp__方法,没有__lt__等6个方法,相对__cmp__一个方法来说,现在的比对方法种类丰富了,Python 2.1引入了富比较方法,Python3.4之后作废了__cmp__方法;
- 比较方法除了简单的比较大小之外,还可以用于排序,从Python2.4开始,排序方法sort() 和 函数sorted() 都增加了一个 ‘key’ 参数,用来在进行比较之前指定每个元素上要调用的函数,这个函数的返回值老猿认为只要是任何可比较大小的数据类型(含定义了__lt__方法的自定义类)都可以,这种返回值比单纯的__cmp__三个返回值(0、1、-1)范围更丰富;
- 对于支持复杂比较的类,每种比较方法调用对应的独立富比较方法而无需共用一个__cmp__方法,从而比一个__cmp__方法要考虑不同情况的实现简单、运行时性能高效;
- 富比较方法可以直接映射到对应的操作符如“<”,操作更方便简洁。
以上分析,不知是否正确和全面,请各位大拿指教。
关于富比较方法的介绍请大家参考:
1、《第8.21节 Python中__lt__、__gt__等 “富比较”(“rich comparison”)方法用途探究》
2、《第8.22节 Python案例详解:重写 “富比较”方法控制比较逻辑》。
老猿Python,跟老猿学Python!
博客地址:https://blog.csdn.net/LaoYuanPython
请大家多多支持,点赞、评论和加关注!谢谢!