Java集合比较器的实现

    技术2025-12-23  21

    Java集合比较器的实现

    一、基本概念

    Comparable和Comparator接口都是为了对类进行比较,众所周知,诸如Integer,double等基本数据类型,java可以对他们进行比较,而对于类的比较,需要人工定义比较用到的字段比较逻辑。可以把Comparable理解为内部比较器,而Comparator是外部比较器。

    Comparable

    Comparable是在集合内部定义的方法实现的排序,位于java.util下。是一个对象本身就已经支持自比较所需要实现的接口,如String、Integer自己就实现了Comparable接口,可完成比较大小操作。自定义类要在加入list容器中后能够排序,也可以实现Comparable接口,在用Collections类的sort方法排序时若不指定Comparator,那就以自然顺序排序。所谓自然顺序就是实现Comparable接口设定的排序方式。

    代码实现:

    定义一个学生类,将学生按照学号(id)从小到大的顺序进行排序打印

    public class Student implements Comparable { private int id; private int age; public Student(int id, int age) { this.id = id; this.age = age; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } public int getId() { return id; } public void setId(int id) { this.id = id; } @Override public String toString(){ final StringBuilder sb=new StringBuilder("{"); sb.append("\"id\":").append(id); sb.append("\"age\":").append(age); sb.append('}'); return sb.toString(); }

    重写compareTo方法,从小到大比较打印,实现compareable方法。

    //指定通过ID进行比较 @Override public int compareTo(Object o) { Student o1 = (Student) o; return id-o1.getId(); }

    Comparator

    Comparator是在集合外部实现的排序,位于java.lang下。是一个专用的比较器,当这个对象不支持自比较或者自比较函数不能满足要求时,可写一个比较器来完成两个对象之间大小的比较。Comparator体现了一种策略模式(strategy design pattern),就是不改变对象自身,而用一个策略对象(strategy object)来改变它的行为。使用方法只能用Collections类的sort方法,并且是传递两个参数进去(List list,Class class),第一个参数是集合的对象list,第二个是实现了comparator接口的实现类的对象。

    总而言之Comparable是自已完成比较,Comparator是外部程序实现比较。

    代码如下: 同样使用上述的student类,在外部程序实现comparator方法,实现按照年龄进行排序

    static class DiyStudent implements Comparator<Student>{ //指定按照年龄进行排序 @Override public int compare(Student o1, Student o2) { return o1.getAge()-o2.getAge();//按照年龄从小到大的排序 } }
    Processed: 0.015, SQL: 9