• Comparable与Comparator


    Comparable

    comparable是java的接口,该接口对实现它的每个类的对象进行整体排序。 compareTo 方法被称为它的比较方法。实现此接口的对象列表或数组可以通过 Collections.sort或 Arrays.sort进行自动排序,而无需指定比较器。

    Comparator

    comparator也是java的接口,对任意类型集合对象进行整体排序,排序时将此接口的实现传递给Collections.sort方法或者Arrays.sort方法排序。

      两者的作用类似,并没有什么区别,comparator更像是对comparable的补充。比如我们定义了一个Grade类(学生成绩),该类包括了学生id、语文成绩与数学成绩,此时Grade实现Comparable接口,

    重写compareTo()方法,实现按语文成绩排序。但如果需要用到按数学成绩排序的序列时,可以使用Comparator重新定义排序规则,而不需要去修改原来的排序规则。以下为代码实现:

    public class Grade implements Comparable<Grade>{
        private String stuId;
        private int chinese;
        private int math;
    
        public String getStuId() {
            return stuId;
        }
    
        public void setStuId(String stuId) {
            this.stuId = stuId;
        }
    
        public int getChinese() {
            return chinese;
        }
    
        public void setChinese(int chinese) {
            this.chinese = chinese;
        }
    
        public int getMath() {
            return math;
        }
    
        public void setMath(int math) {
            this.math = math;
        }
    
    
        @Override
        public int compareTo(Grade o) {
            return this.chinese-o.chinese;
        }
    }
    public class Test {
        public static void main(String[] args) {
            Grade grade = new Grade();
            grade.setStuId("12");
            grade.setChinese(23);
            grade.setMath(34);
    
            Grade grade1 = new Grade();
            grade1.setStuId("13");
            grade1.setChinese(25);
            grade1.setMath(54);
    
            Grade grade3 = new Grade();
            grade3.setStuId("14");
            grade3.setChinese(12);
            grade3.setMath(59);
            List<Grade> list = new ArrayList<>();
            list.add(grade1);
            list.add(grade);
            list.add(grade3);
            System.out.println("按語文排序:");
            Collections.sort(list);
            for (Grade grade2 : list) {
                System.out.println(grade2.getStuId()+" "+grade2.getChinese()+" "+grade2.getMath());
            }
    
            System.out.println("按數學排序:");
            Collections.sort(list,(x,y)->{return x.getMath()-y.getMath();});
    /*   Collections.sort(list, new Comparator<Grade>() {
    @Override
    public int compare(Grade o1, Grade o2) {
    return o1.getMath()-o2.getMath();
    }
    });*/
    for (Grade grade2 : list) { System.out.println(grade2.getStuId()+" "+grade2.getChinese()+" "+grade2.getMath()); } } }

    执行结果:

    重写compare方法,采用lambda表达式实现,比匿名内部类实现语法上更简单明了。

  • 相关阅读:
    JS表格测试
    2018电脑选购配置
    一句话技巧总结
    我的码风
    友情链接
    写代码时需要注意的一些东西
    他是 ISIJ 第四名,也是在线知名题库的洛谷“网红”
    从并查集的按秩合并看一类构造性问题
    高一上期末考游记
    P3233 [HNOI2014]世界树
  • 原文地址:https://www.cnblogs.com/menbo/p/11369630.html
Copyright © 2020-2023  润新知