还是java牛逼,一行代码搞定各种排序
排序大家都经常用的吧,下面是个学生类,2 个字段:id[学号],score[分数],
public 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<Stu> stuList = new ArrayList<>(); stuList.add(new Stu(2, 30)); stuList.add(new Stu(1, 30)); stuList.add(new Stu(3, 50)); stuList.add(new Stu(4, 40));
需求:score desc,id asc 对 stuList 中的学生信息进行排序,然后输出结果,用 java 实现特别的简单,2 行代码搞定,如下:
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}
是不是特别简单,这里使用到了 java 中的 stream 来操作的,stream 中有个 sorted 方法,需传入比较器:Comparator,我们传入的是:
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升序排序。
故乡明
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 25岁的心里话