在学习scala的过程中,其中的集合确实会难倒很多人,今天就主要分享我对sortBy函数的理解
这是官网对sortBy函数的解释和例子,个人对此没有怎么看懂,因此自己摸索实践,慢慢总结出来自己的想法,
这个是在编译器里面自动出来的
首先我们看,这个sortBy[B],第一个B是指返回值,
括号里面的f:(Int)=>B代表传入一个参数,这个参数类型是Int类型,这个函数的返回值是B类型的
后面的implicit ord:Ordering[B]这个是排序的规则
话不多说,上代码案例
第一个案例是对一个整数型的list进行排序
@Test
def testInt(): Unit ={
var list = List(1,2,3,6,4,8,9,0)
println(list.sortBy(sortIntRule))
}
def sortIntRule(i:Int) ={
i match {
case 1=> 2
case 2=> 1
case 3=> 4
case _=> 0
}
}
这个排序的规则是,传入这个函数,必须只有一个Int类型的参数,然后进行类型匹配,遇到1了按照2进行排序,遇到2了按照1进行
排序,这样真正排序下来是2再到1,遇到3了按照4开始排序,其他的都按照0排序,也就是最小的,这样的意思就是除了1,2,3的其
他数据都是按照0排序,也就是最小的,在这个LIST中应该6,4,8,9,0,然后接下来按照模式匹配后的顺序排序,也就是1,2,4,
对应list里面的2,1,3,总的排序结果就是6,4,8,9,0,2,1,3
测试结果如上图
第二个案例是对对象进行排序
首先我定义了一个person类,并有默认传参,这里变量为大写主要是为了不冲突
package exercise.dto
class Person(age:Int,name:String,salary:Int) {
var AGE = age
var NAME = name
var SALARY = salary
override def toString = s"Person($AGE, $NAME, $SALARY)"
}
然后写他的测试方法
@Test
def TestSortBy(): Unit = {
val personOne = new Person(18, "zhangsan", 10000)
val personTwoA = new Person(20, "lisiA", 9000)
val personTwoB = new Person(20, "lisiB", 10000)
val personThree = new Person(15, "wangwu", 8000)
var list = new ListBuffer[Person]
list.+=(personOne, personTwoA,personTwoB, personThree)
println(list.sortBy(sortRule)(Ordering.Tuple2(Ordering.Int.reverse, Ordering.Int.reverse)))
}
def sortRule(person: Person): (Int, Int) = {
(person.AGE, person.SALARY)
}
这里我传入的函数是sortRule,这个函数的意思是根据person对象的年龄和薪水进行排序,如果年龄出现一样的再按照薪水进行排序
然后后面的Ording,Tuple2(Ordering.Int.reverse,Ordering.Int.reverse)意思是有两个参数的元组,第一个Int型的按照从大到小排序,
reverse指从大到小排序,第二个也是从大到小排序,默认是从小到大的排序。
执行结果如上图,