Scala里面的排序函数的使用

Posted 我是攻城师

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Scala里面的排序函数的使用相关的知识,希望对你有一定的参考价值。

排序方法在实际的应用场景中非常常见,Scala里面有三种排序方法,分别是: sorted,sortBy ,sortWith

分别介绍下他们的功能:

(1)sorted

对一个集合进行自然排序,通过传递隐式的Ordering

(2)sortBy

对一个属性或多个属性进行排序,通过它的类型。

(3)sortWith

基于函数的排序,通过一个comparator函数,实现自定义排序的逻辑。

例子一:基于单集合单字段的排序

Scala里面的排序函数的使用

结果:

Scala里面的排序函数的使用

例子二:基于元组多字段的排序

注意多字段的排序,使用sorted比较麻烦,这里给出使用sortBy和sortWith的例子

先看基于sortBy的实现:

Scala里面的排序函数的使用

结果:

Scala里面的排序函数的使用


再看基于sortWith的实现:

Scala里面的排序函数的使用

从上面可以看出,基于sortBy的第二种实现比较优雅,语义比较清晰,第三种灵活性更强,但代码稍加繁琐

例子三:基于类的排序

先看sortBy的实现方法 排序规则:先按年龄排序,如果一样,就按照名称降序排

Scala里面的排序函数的使用


结果:

Scala里面的排序函数的使用


再看sortWith的实现方法:


结果:

总结:

本篇介绍了scala里面的三种排序函数,都有其各自的应用场景:

sorted:适合单集合的升降序

sortBy:适合对单个或多个属性的排序,代码量比较少,推荐使用这种

sortWith:适合定制化场景比较高的排序规则,比较灵活,也能支持单个或多个属性的排序,但代码量稍多,内部实际是通过java里面的Comparator接口来完成排序的。

实际应用中,可以根据具体的场景来选择合适的排序策略。


以上是关于Scala里面的排序函数的使用的主要内容,如果未能解决你的问题,请参考以下文章

2021年大数据常用语言Scala(二十五):函数式编程 排序

Scala的map实现key和value排序及各种排序比较等知识讨论

Scala的Seq集合中的排序实现

Scala 问题对 Stack[A] 使用 PriorityQueue 非默认排序

使用带有 PriorityQueue (Scala) 的隐式排序时遇到问题

scala--使用List编写归并排序