Arrays.sort()方法参数为自定义对象数组时的使用
简述
首先Comparable< T t >是一个接口其中有一个抽象方法compareTo,当sort方法参数传入自定义对象数组时,我们跟随源码可以看到最终是以Comparable< T t >这个接口关联到参数数组中对象所在的类中的compareTo方法进行排序的,因此参数对象所对应的类必须实现Comparable< T t >接口,并且重写compareTo方法规定排序策略。
举例说明
1. 首先创建一个类
我们创建一个Lei类(类名自定义)其中有一个String类型的成员变量bookname和int类型的成员变量count,这个类实现了Comparable< T t >接口,并且重写了compareTo(compareTo方法的返回值是大于0,等于0或小于0三种),排序策略是根据int类型的成员变量count的大小进行排序的
this.getCount()-o.getCount()可以大于0,等于0或小于0
public class Lei implements Comparable<Lei> {
private String bookname;
private int count;
public Lei(String bookname, int count) {
super();
this.bookname = bookname;
this.count = count;
}
public String getBookname() {
return bookname;
}
public void setBookname(String bookname) {
this.bookname = bookname;
}
public int getCount() {
return count;
}
public void setCount(int count) {
this.count = count;
}
@Override
public String toString() {
return "Lei [书名=" + bookname + ", 数量=" + count + "]\n";
}
@Override
public int compareTo(Lei o) {
// TODO Auto-generated method stub
return this.getCount()-o.getCount();
}
}
2. 创建一个测试类
其中创建了一个Lei类的对象数组,通过构造方法给成员变量赋值,初始的时候是乱序的,我们把数组名传入sort方法中,然后输出对象数组的内容
public class Test {
public static void main(String[] args) {
Lei[] arr=new Lei[5];
arr[0]=new Lei("AA",3);
arr[1]=new Lei("CC",5);
arr[2]=new Lei("FF",1);
arr[3]=new Lei("BB",4);
arr[4]=new Lei("SS",2);
Arrays.sort(arr);
System.out.println(Arrays.toString(arr));
}
}
3.运行结果
我们可以看到数组中的对象已经根据数量(count)的大小排序好了