环境带入
一
现在要求设计一个学生类,此类包含姓名,年龄,成绩,并产生一个对象数组,要求按成绩由高到底排序,如果成绩相等,则按年龄由低到高排序,如果直接编写排序操作,会比较麻烦。所以此时只需要实现Comparable接口,该接口就是用于指定对象排序规则的,然后用Arrays的sort()方法排序。
二
如果一个类已经开发完成,但是在此类建立初期并没有实现Comparable接口,此时肯定无法进行对象排序操作,所以为了解决这样的问题,java有定义了另一个比较器的操作接口—Comparator,很明显,与Comparable相比,Comparator接口明显是一种补救的做法,只要是排序,在java中,Comparator永远是标椎。
Comparable接口的定义如下
public interface Comparable<T>{
public int compareTo(T o);
}
其中只有一个方法compareTo,此方法返回一个int类型的数据,但值只有三种
1:表示大于。换位,
-1:表示小于。不换位
0:表示等于。不换位
public int compareTo(Student stu) {
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;
}
}
}
compareTo()方法解析
如果当前对象this大于形参对象obj,返回正整数时,表示升序,若返回负整数表示降序
如果当前对象this小于形参对象,则返回负整数时,表示降序,若返回正整数时表示升序
如果相同返回0。
返回的是整数还是负数完全可以自己定义。
若对于当前对象this与形参对象stu,不理解时,不必深究,可将此方法当做固定公式记住,然后对于自己想要排序的对象的属性进行比较即可,比如这个例子中是以成绩排序为主,若成绩相同,在比较年龄