JAVA中关于实现Comparable接口问题,为什么对于使用Arrays排序的对象都要实现这个接口?

在阅读Java核心券1的过程中,对于使用Arrays排序的对象都要实现Comparable接口的问题,有2个疑问?

1、为什么必须要实现Comparable这个接口,而不可以在我们的类中手动提供一个compareTo方法,而必须实现Comparable接口?

答:为Arrays.sort(Object[] objs)方法它内部必须把Object数组里面强制转换为Comparable类型,才可以调用comparaTo()方法。而你仅仅在类中写ComparaTo()方法,那它怎么调?你传进去的是Object而不是其他,Object没这个方法。

      或者说,因为sort方法不(能)依赖你的类的实现,所以不能进行 ((OP_s_Class)item).compareTo(...)的调用,而只能用((Comparable)item).compareTo(...)的调用。因为要用OP_s_Class就需要在编译sort的代码时import OP_s_Class,这是不可能的。但import Comparable则会轻松愉快。

 

2、

《JAVA核心技术》卷一P206讲道:“有人认为,将Arrays类中的sort方法定义为接受一个Comparable[]数组就可以在使用元素类型没有实现Comparable接口的数组作为参数调用sort方法时,由编译器给出错误报告。但事实并非如此。在这种情况下,sort方法可以接收一个Object[]数组,并对其进行笨拙的类型转换:

    //from the standard library--not recommended

    if(((Comparable)a[i]).compareTo(a[j])>0)

      {

        //rearrange a[i] and a[j]

          ..........

      }         

           如果a[i]不属于实现了Comparable接口的类,那么虚拟机就会抛出一个异常。”

 

          一开始,我觉得将Arrays类中的sort方法定义为接受一个Comparable[]数组作为参数很好啊,为什么不行呢??

答:之所以sort允许使用非Comparable类型的数组进行调用,是因为非Comparable类型的数组可能存在着Comparable的内容。 比如基类Person类是不能比较的,但派生类Student类可以比较,这时构造一个Person类的数组,然后把Student实例填进去,然后拿这个数组排序是没有问题的。我这里写了一个简单的测试类:

import java.util.Arrays;

class Person
{
	private String name;
	private int age;
	
	public Person()
	{
		
	}
	
	public Person(String name,int age)
	{
		this.name = name;
		this.age = age;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public int getAge() {
		return age;
	}

	public void setAge(int age) {
		this.age = age;
	}
}


class Student extends Person implements Comparable<Student>
{
	public Student()
	{
		
	}
	
	public Student(String name,int age,int grade)
	{
		super(name,age);
		this.grade = grade;
	}
	private int grade;
	
	@Override
	public int compareTo(Student o) {
		if (this.grade > o.grade)
			return 1;
		else if (this.grade == o.grade)
			return 0;
		else
			return -1;
	}
	
}

public class Test {
	public static void main(String[] args)
	{
		//定义Person数组
		Person [] persons = new Person[3];
		for (int i=0;i<3;i++)
		{
			persons[i] = new Person();
		}
		
		Test(persons);    //not ok
		
		//定义student数组
		Student [] students = new Student[3];
		for (int i=0;i<3;i++)
		{
			students[i] = new Student();
		}
		Test(students);    //ok
		
		//定义person数组存储student对象
		Person [] persons2 = new Person[3];
		for (int i=0;i<3;i++)
		{
			persons2[i] = new Person();
		}
		
		Test(persons2);    //not ok 
	}
	
	
	
	public static void Test(Comparable arrays[])
	{
		
	}
}

 

 

  • 6
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值