还是java牛逼,一行代码搞定各种排序
2021-03-08 11:30
标签:ide err add 简单 nbsp string convert 输出 print 排序大家都经常用的吧,下面是个学生类,2 个字段:id[学号],score[分数], 来个集合,放几个学生进去 需求:score desc,id asc 对 stuList 中的学生信息进行排序,然后输出结果,用 java 实现特别的简单,2 行代码搞定,如下: 是不是特别简单,这里使用到了 java 中的 stream 来操作的,stream 中有个 sorted 方法,需传入比较器:Comparator,我们传入的是: 解释一下代码 还是java牛逼,一行代码搞定各种排序 标签:ide err add 简单 nbsp string convert 输出 print 原文地址:https://www.cnblogs.com/luweiweicode/p/14203297.htmlpublic class Stu {
//编号
private Integer id;
//分数
private Integer score;
public Stu(Integer id, Integer score) {
this.id = id;
this.score = score;
}
// getter、setter大家自己补上
@Override
public String toString() {
return "Stu{" +
"id=" + id +
", score=" + score +
‘}‘;
}
}
List
stuList.stream().sorted(Comparator.comparing(Stu::getScore).reversed().thenComparing(Stu::getId)).forEach(System.out::println);
Stu{id=3, score=50}
Stu{id=4, score=40}
Stu{id=1, score=30}
Stu{id=2, score=30}
Comparator.comparing(Stu::getScore).reversed().thenComparing(Stu::getId)。
Comparator.comparing(Stu::getScore) 得到score升序比较器
Comparator.comparing(Stu::getScore).reversed():将score升序比较器反转,那么就得到score降序比较器
Comparator.comparing(Stu::getScore).reversed().thenComparing(Stu::getId):注意这里面用到了thenComparing,这个表示前面的比较器得到的结果相同的时候,走thenComparing函数中指定的比较方式,即按照Stu中的id升序排序。