16.Java 基础 - Comparable & Comparator

基本概念

Comparable & Comparator 的定义如下:

  • 当一个类实现了 Comparable 接口,表示该类支持排序。

  • 当一个类实现了 Comparator 接口,表示该类是一个比较器。

当一个类不支持排序,即未实现 Comparable 时。要对该类的对象集合或数组进行排序:

  • 修改类的结构,该类实现 Comparable 接口。
  • 不修改类结构,新建类实现 Comparator 接口,作为该类的比较器。

不难看出,实现 Comparable 接口的方式比实现 Comparator 接口的耦合性要强一些。所以还是推荐尽量使用 Comparator 接口实现排序功能。


原理分析

下面来分析它们的原理:


1.Comparable

当一个类实现了 Comparable 接口,表示该类支持排序。

若存在该类对象的集合或数组,则可以通过 Collections.sortArrays.sort 进行排序。

  • 接口源码

    public interface Comparable<T> {
        public int compareTo(T o);
    }
  • 自定义接口实现类

    public class Person implements Comparable<Person> {
        private String name;
        private int age;
    
        public Person(String name, int age) {
            this.name = name;
            this.age = age;
        }
    
        @Override
        public String toString() {
            return this.name + "-" + this.age;
        }
    
        // 关键
        @Override
        public int compareTo(Person p) {
            return this.age - p.age;
        }
    }
  • 调用

    Person[] pers = { new Person("b", 400), new Person("a", 40) };
    // 排序,默认按从小到大排序
    Arrays.sort(pers);
    for (Person per : pers) {
        System.out.println(per.toString());
    }
    // 输出结果:
    // a-40
    // b-400

2.Comparator

当一个类本身并没有实现 Comparable 接口,说明该类不支持排序。

这种情况下,仍然要对该类的集合或数组进行排序,则需要创建一个该类的比较器。

新建类实现了 Comparator 接口,表示自己是一个比较器。

  • 接口源码

    public interface Comparator<T> {
        int compare(T o1, T o2);
        boolean equals(Object obj);
    }
  • 自定义接口实现类

    public class Person {
        private String name;
        private int age;
    
        // 省略 getter 方法...
    
        public Person(String name, int age) {
            this.name = name;
            this.age = age;
        }
    
        @Override
        public String toString() {
            return this.name + "-" + this.age;
        }
    }
    
    // 关键 -> 创建 Peerson 类的比较器
    public class PersonComparator implements Comparator<Person> {
    
        @Override
        public int compare(Person p1, Person p2) {
            return p1.getAge() - p2.getAge();
        }
    
    }
  • 调用

    Person[] pers = { new Person("b", 400), new Person("a", 40) };
    PersonComparator pc = new PersonComparator();
    Arrays.sort(pers,pc);
    for (Person per : pers) {
        System.out.println(per.toString());
    }
    // 输出结果同上个例子

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

oxf

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值