如何使用工具类Arrays的sort方法将对象数组进行排序?

148 阅读1分钟

在工具类Arrays中,有一个sort(Object[] a)方法,它承诺可以对对象数组进行排序,但前提是满足以下这个条件: 对象所属的类必须实现Comparable<T>接口。

Comparable<T>接口只有一个方法compareTo(T other);实现compareTo(T other)方法,要求调用x.compareTo(y)的时候,这个compareTo方法实际上必须能够比较两个对象,并返回一个整数,即当x小于y时,返回一个负数;当x等于y时,返回0;当x大于y时,返回一个正数。

如果按照以上的规则返回整数,那么Arrays的sort方法就会将此数组进行升序排序;若想进行降序排序,只需要将上面的规则颠倒,也就是当x小于y时,返回一个正数;当x大于y时,返回一个负数。

以下是示例代码:

public class Employee implements Comparable<Employee>{

    private String name;//员工姓名
    private double salary;//薪水
    
    public Employee(String name, double salary) {
        this.name = name;
        this.salary = salary;
    }

    @Override
    public int compareTo(Employee o) {
        return Double.compare(salary,o.salary);
        //如果salary小于o.salary,就返回一个负数;等于就返回0;大于o.salary就返回一个正数
    }
}

public class test {

    public static void main(String[] args) {
    
        Employee[] employees = new Employee[4];
        
        Employee employee1 = new Employee("aaa",99);
        Employee employee2 = new Employee("bbb",88);
        Employee employee3 = new Employee("ccc",77);
        Employee employee4 = new Employee("ddd",66);
        
        employees[0] = employee1;
        employees[1] = employee2;
        employees[2] = employee3;
        employees[3] = employee4;
        
        //因为Employee类实现了Comparable接口,所以可以使用Arrays类的sort方法进行排序
        Arrays.sort(employees);
        
        //排序后employees的顺序是employee4、employee3、employee2、employee1(按薪水升序排序)
    }
}