11.13 Comparable接口
11.13.1 比较器的基本应用
在讲解数组时,曾经讲过可以直接使用java.util.Arrays类进行数组的排序操作,而且Arrays类中的sort方法被重载多次,可以对任意类型的数组排序,排列时
会根据数值的大小进行排序。同样此类也可以对Object数组进行排序,但是要使用此种方法排序也是有要求的,即对象所在的类必须实现Comparable接口,此接
口就是用于指定对象排序规则的。Comparable接口的定义如下:
public interface Comparable<T>{ public int compareTo(T o) ; }
从以上定义中可以发现,在Comparable接口中也使用了Java的泛型技术。其中只有一个compareTo方法,此方法返回一个int类型的数据,但是此int的值只能是以
下3种:
1:表示大于。
-1:表示小于。
0:表示相等。
下面来看一下具体的应用。例如,现在要求设计一个学生类,此类包含姓名、年龄、成绩,并产生一个对象数组,要求按成绩由高到低排序,如果成绩相等,则
按年龄由低到高排序。如果直接编写排序操作,则会比较麻烦,所以,此时来观察如何使用Arrays类中的sort()方法进行排序操作。
范例:使用比较器进行排序操作
package org.lxh.demo11.comparabledemo; class Student implements Comparable<Student> { // 指定类型为Student private String name;
private int age; private float score; public Student(String name, int age, float score) { this.name = name;
this.age = age; this.score = score; } public String toString() { return name + "\t\t" + age + "\t\t" + score;
} public int compareTo(Student stu) { // 覆写compareTo()方法,实现 排序规则的应用 if (this.score > stu.score) {
return -1; } else if (this.score < stu.score) { return 1; } else { if (this.age > stu.age) {
return 1; } else if (this.age < stu.age) { return -1; } else { return 0;
} } } }; public class ComparableDemo01 { public static void main(String[] args) { Student stu[] = { new
Student("张三", 20, 90.0f), new Student("李四", 22, 90.0f), new Student("王五", 20, 99.0f), new
Student("赵六", 20, 70.0f), new Student("孙七", 22, 100. 0f) }; java.util.Arrays.sort(stu); // 进行排序操作
for (int i = 0; i < stu.length; i++) { // 输出数组中的内容 System.out.println(stu[i]); } } } 程序运行结果:
孙七 22 100.0 王五 20 99.0 张三 20 90.0 李四 22 90.0 赵六 20 70.0
由程序运行结果可以发现,程序完成了要求的排序规则,对对象数组进行了排序操作,但是要特别提醒读者注意的是,如果在此时Student类中没有实现Comparab
le接口,则在执行时会出现以下异常:Exception in thread "main" java.lang.ClassCastException: org.lxh.demo11. comparabledemo.Student cannot be
cast to java.lang.Comparable at java.util.Arrays.mergeSort(Unknown Source) at java.util.Arrays.sort(Unknown Source) at
org.lxh.demo11.comparabledemo.ComparableDemo01.main(ComparableDemo01. java:35)
此异常是类型转换异常,因为在排序时,所有的对象都将向Comparable进行转换,所以,一旦没有实现此接口就会出现以上错误。