您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

为什么从Python3.0中的sort / sorted中删除了cmp参数?

为什么从Python3.0中的sort / sorted中删除了cmp参数?

对于两个物体ab__cmp__要求 之一 a < ba == ba > b是真实的。但是,这可能并非如此:考虑套,它是非常普遍, 这些都不 是真实的,例如{1, 2, 3}VS {4, 5, 6}

于是__lt__和朋友介绍了。但这给Python留下了两种单独的排序机制,这有点荒谬,因此在Python 3中删除了灵活性较差的一种。

您实际上不必实现所有六个比较方法。您可以使用@total_ordering装饰器,仅实现__lt____eq__

编辑:还请注意,在排序的情况下,key函数可能比cmp:效率更高:在您给出的示例中,Python可能必须调用Python比较函数O(n²)次。但是一个key函数只需要调用O(n)次,并且如果返回值是内置类型(通常是这样),则O(n²)成对比较将通过C。

python 2022/1/1 18:31:34 有575人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶