Comparable接口

 

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进行转换,所以,一旦没有实现此接口就会出现以上错误。


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值