Kotlin 集合排序

1. 先构造一个业务类

//定义一个Person类,有name 和 age 两属性

data class Person(var name: String, var age: Int)
var personList: MutableList = mutableListOf()
personList.add(Person("Jim", 12))
personList.add(Person("A-Lin", 12))
personList.add(Person("Tom", 11))
personList.add(Person("Mary", 14))

2. 使用 sortBy 排序

fun main(args: Array) { 
    //构造personlist... println("----排序前----")
    personList.forEach(::println) println("----排序后----") 
    //按年龄排序
    personList.sortBy ({ it.age })
    //或者写成 //personList.sortBy(Person::age) 
    personList.forEach(::println)
}
sortBy 为正序排列,跟其对应的降序方法为 sortByDescending
personList.sortByDescending({ it.age })

3. 使用 sortWith 排序

实际情况下,我们的业务需求往往需要根据多个条件来排序,这时我们就需要用到 sortWith 方法

//先根据age 升序排列,若age相同,根据name升序排列
personList.sortWith(compareBy({ it.age }, { it.name }))
sortWith 方法中,传入的 compareBy({属性1},{属性2},…)参数,
 compareBy() 这里的参数个数是可变的,但是都是默认的升序排列。
所以我们还可以根据自己的实际需求,给sortWith传入一个Comparator对象,
来达到一个更高级更复杂的逻辑

//构造一个Comparator对象,完成排序逻辑:先按age降序排列,若age相同,则按name升序排列
val c1: Comparator = Comparator { o1, o2 -> 
      if (o2.age == o1.age) {   
          o1.name.compareTo(o2.name)
      } else { 
          o2.age - o1.age 
      }
 }
personList.sortWith(c1)

4. 通过 data class 实现 Comparable 接口来排序

重新构造 Person 类
data class Person(var name: String, var age: Int) : Comparable {
     override fun compareTo(other: Person): Int {
         if (this.age == other.age) { 
              return this.name.compareTo(other.name) 
         } else {
             return other.age - this.age 
         } 
    }
}调用 list.sorted()方法排序
//sorted 方法返回排序好的list
val sorted = personList.sorted()
sorted.forEach(::println)

你可能感兴趣的:(Kotlin 集合排序)