Scala比较器---Ordered与Ordering
分类:
Spark
1.Ordered 和 Ordering
Scala提供两个特质(trait)Ordered
与Ordering
用于比较。其中,Ordered混入(mix)Java的Comparable接口,而Ordering则混入Comparator接口。众所周知,在Java中
- 实现Comparable接口的类,其对象具有了可比较性;
- 实现comparator接口的类,则提供一个外部比较器,用于比较两个对象。
Ordered与Ordering的区别与之相类似:
- Ordered特质定义了相同类型间的比较方式,但这种内部比较方式是单一的;
- Ordering则是提供比较器模板,可以自定义多种比较方式。
2.Ordered
Ordered特质更像是rich版的Comparable接口,除了compare方法外,更丰富了比较操作(<, >, <=, >=):
1 2 3 4 5 6 7 8 | trait Ordered[T] extends Comparable[T] { def compare(that: A): Int def < (that: A): Boolean = (this compare that) < 0 def > (that: A): Boolean = (this compare that) > 0 def < = (that: A): Boolean = (this compare that) < = 0 def > = (that: A): Boolean = (this compare that) > = 0 def compareTo(that: A): Int = compare(that) } |
3.Ordering
Ordering,内置函数Ordering.by
与Ordering.on
进行自定义排序:
1 2 3 4 5 6 7 8 | import scala.util.Sorting val pairs = Array(( "a" , 5 , 2 ), ( "c" , 3 , 1 ), ( "b" , 1 , 3 )) / / sort by 2nd element Sorting.quickSort(pairs)(Ordering.by[(String, Int , Int ), Int ](_._2)) / / sort by the 3rd element, then 1st Sorting.quickSort(pairs)(Ordering[( Int , String)].on(x = > (x._3, x._1))) |
参考文献:
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现
2018-11-10 numpy的ravel()和flatten()函数