在工具类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(按薪水升序排序)
}
}