参考地址 Comparable 的 使用
在聊 Comparable 和 Comparator 之前,我觉得我们可以先聊聊Int数组的排序! 现在呢,下面有一个非常简单的数组
如:int[] array = {3,8,5,3,12,10}; 要求呢就是对这个int数组进行一个从大到小或者从小到大的排序。我相信你们等下就会和我说 冒泡啊等的算法!但我们今天不聊这些算法。来点简单的!
在java 里面有个Arrays 的类(java.util.Arrays),他里面有一个sort的方法(public static void sort(int[] a)),这个方法就可以直接对这个数组进行排序! 而且这个方法还是由static修饰的,意思就是和你说,你别实例化哈,直接拿来用!
int[] array = {3,8,5,3,12,10};
Arrays.sort(array);
for(int index = 0;index < array.length;index++){
System.out.print(array[index]+",");
}
结果
3,3,5,8,10,12,
写到这里,大家看到这个sort排序完是从小到大的一个顺序排的,那怎么从大到小呢? for循环反着输出不就好了么!
int[] array = {3,8,5,3,12,10};
Arrays.sort(array);
for(int index = array.length-1;index >=0;index--){
System.out.print(array[index]+",");
}
结果
12,10,8,5,3,3,
那么ok是吧,讲这个的目的呢是为了引出我下一个需求。现在我们对int数组的排序应该已经掌握了!是不是真的很简单是吧!
听明白的给我扣个6!!!
来进入正题哈! 现在我有一个需求,我手上呢有一个UserBean类,bean里面的字段有(id,username,age)三个字段。 如果你userBean不会写的,可以关电脑了哈。如下:
public class UserBean {
private String id;
private String username;
private Integer age;
// set and get
}
那现在我要做的呢就是,我要对这个UserBean数组进行一个按 年龄 大小排序的功能。什么意思呢!就是age越大的人,最先输出。
要做这个呢,我们也是用到了Arrays.sort 这个排序的方法!但不同的是,我们之前用的是int数组,现在我们用的是这个UserBean数组。如果你想对这个UserBean数组进行排序,你要多做一件事,就是让这个 UserBean类去 实现Comparable 的接口,并重写 里面 comparaTo 的方法。注意,这个接口是可以提供泛型的
public class UserBean implements Comparable<UserBean> {
private String id;
private String username;
private String age;
// 省略了 set and get
public int compareTo(UserBean o) {
// TODO Auto-generated method stub
return 0;
}
}
compareTo 方法的返回值为三个,分别是[-1 ,0 ,1 ]具体重写的代码如下
public class UserBean implements Comparable<UserBean> {
private String id;
private String username;
private String age;
// 省略了 set and get
public int compareTo(UserBean o) {
if(this.age > o.getAge()){
return 1;
}else if(this.age < o.getAge()){
return -1
}else{
return 0;
}
}
}
写完这个UserBean后,我们就可以去调用 Arrays.sort 这个方法了
UserBean[] array = UserBean[3];
array[0] = new UserBean("1","zhangsan","11");
array[1] = new UserBean("2","lisi","12");
array[2] = new UserBean("3","wangwu","13");
Arrays.sort(array);