Java中Arrays.sort()⾃定义数组的排序
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 的⼤⼩进⾏排序的
public class Lei implements Comparable<Lei>{
private String bookname;
private int count;
public Lei(String bookname,int count){
super();
this.bookname = bookname;
}
public String getBookname(){
return bookname;
}
public void setBookname(String bookname){
this.bookname = bookname;
}
public int getCount(){
return count;
}
public void setCount(int count){
}
@Override
public String toString(){
return"Lei [书名="+ bookname +", 数量="+ count +"]\n";
}
@Override
public int compareTo(Lei o){
// TODO Auto-generated method stub
Count()-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);
java定义一维数组并赋值arr[2]=new Lei("FF",1);
arr[3]=new Lei("BB",4);
arr[4]=new Lei("SS",2);
Arrays.sort(arr);
System.out.String(arr));
}
}
3.运⾏结果
我们可以看到数组中的对象已经根据数量(count)的⼤⼩排序好了
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论