• 还是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升序排序。
    故乡明
  • 相关阅读:
    OpenCV学习(10) 图像的腐蚀与膨胀(1)
    OpenCV学习(6) 文件和Mat之间的数据交换
    OpenCV学习(5) Mat的基本操作(2)
    OpenCV学习(4) Mat的基本操作(1)
    OpenCV学习(3) OpenCV框架
    OpenCV学习(2) OpenCV的配置
    OpenCV学习(1) OpenCV的安装
    Android触控屏幕Gesture(GestureDetector和SimpleOnGestureListener的使用教程) 分类:Androidandroid实例
    转载 C++实现的委托机制
    C++如何禁止掉对象的复制操作
  • 原文地址:https://www.cnblogs.com/luweiweicode/p/14203297.html
Copyright © 2020-2023  润新知