java 编程 最牛_还是java牛逼,一行代码搞定各种排序

f1d3edc80b956993123aca38b8b91e1f.png

排序大家都经常用的吧,下面是个学生类,2 个字段:id[学号],score[分数],

public classStu {//编号

privateInteger id;//分数

privateInteger score;publicStu(Integer id, Integer score) {this.id =id;this.score =score;

}//getter、setter大家自己补上

@OverridepublicString toString() {return "Stu{" +

"id=" + id +

", score=" + score +

‘}‘;

}

}

来个集合,放几个学生进去

List 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升序排序。

还是java牛逼,一行代码搞定各种排序

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值