我们都知道,在java中,整数是可以进行排序的,数组也是可以进行排序的,Arrays.sort(), 其实, java中任何对象都是可以进行比较的,只要要自己定义一下比较的标准.
一.当比较的类是我们自己创建的引用类,比如下面这个Point()类,如何进行对象的比较():
1.在该对象所表示的类中实现Comparable接口(这个接口提供了一个比较的方法)
2.重写compareTo方法(这是为了规定比较的准则)
3.自定义比较的规则
重写compareTo方法的注意细则
在该方法中就需要我们自定义比较规则
注意:如果该方法返回的是boolean,那么结果就只有两种
所以该方法是需要返回一个int类型的值,这样,就能满足比较之下产生的三种情况(相等,大于,小于)
-如果int值>0,则表示当前的对象要大于比较的对象
-如果int值=0,则表示当前的对象要等于比较的对象
-如果int值<0,则表示当前的对象要小于比较的对象
方法中的参数:Point o就表示比较的对象
this点出来的对象就表示当前的对象
public class Point implements Comparable<Point> {
int x;//x坐标
int y;//y坐标
int z;
public Point(int x,int y,int z){
this.x=x;
this.y=y;
this.z=z;
}
@Override
public String toString() {
return "(" + x +"," + y +"," + z +")";
}
@Override
public int compareTo(Point o) {
/**
* 假设Point点钟,x*x-y*y-z*z的值谁大,就表示哪个点就大
*/
return -(this.x*this.x-this.y*this.y-this.z*this.z)+(o.x*o.x-o.y*o.y-o.z*o.z);
}
}
二.当比较的类不是我们自己创建的类而是String这种java中自带的类如何进行比较?
如果比较的对象所表示的类,不是我们自己创建的,例如像String这样的,我们不能在该类中实现Comparable接口,这个时候,sort()方法给我们提供了一个重载的方法,这个重载的方法中就需要我们传入一个比较器Comparator.
这个方法的出现纯粹是因为不能没有自定义类型就不能手动继承Comparable函数,只能另外提供一个方法.
List<String> list2 = new ArrayList<String>();
list2.add("苍老师");
list2.add("波多野结衣");
list2.add("仓木美娜丸子");
list2.add("深田永美");
list2.add("吴签");
Comparator<String> c = new Comparator<String>(){
public int compare(String o1, String o2) {
/**
* 假设是按照字符串长度来比较两个字符串
*/
return o1.length()-o2.length();
}
};
Collections.sort(list2,c);
System.out.println(list2);
这里用到了匿名内部类, 什么情况下使用匿名内部类?
1.当这个类不能直接创建对象,而我们又需要用到该类的类型变量或者对象的时候
2.当这个类的对象只使用一次的时候
例如上面那个方法中创建了一个没有名字的类,这个类继承了Comparator
2.创建了这个没有名字的类的对象,对象名叫做c
3.重写该类中的所有抽象方法
匿名内部类的出现是因为我们需要使用一个抽象类中的方法,但是抽象类是不能new对象的,所以就提供了一种格式来给我们一次机会来使用这个抽象类中的方法.