implements Comparator的方法和implements Comparable的方法相比:前者能使一个类
有多种可以排序的方法,例如,Pig类可以写一种按照name排序的方法的同时,又可以有按照体重进行排序的方法。
※仍然是要覆盖toString()方法※
下面是class WeightSort的代码:
同样的,降序只要在compare()把两者倒过来,不赘述
implements Comparable的方法见:
http://blog.163.com/it_novice/blog/static/20918306920133810327415/
查询API,我们会发现,sort()方法其实除了
sort(List<T> list) 还有一个两个参数不同的
重载的版本:
sort(List<T> list, Comparator<? super T> c)
它的说明翻译过来是:按照我们指定的comparator(规定的方法)来为指定的表排序
【
java.util.Comparator:
public interface Comparator<T>{
int compare(T o1, T o2);
} 】
例:按PIG的名字的升序,和PIG体重的升序,分别将猪猪们排列
以下是新增weight条目的Pig类:
用Comparator接口来写两个有指示排序功能的类:
注意,这里我是把两个关于Pig类的排序类写在了Pig类的外部,为的是省事。
更加结构化的方法是:把两个关于Pig类的排序类写在Pig内部,作为内部类。
可是这也带来个问题,每次创建排序类的实例时都要在之前创建个Pig类实例,其实不太符合逻辑。
下面是class NameSort的代码:
需要implements Comparator<T> T限定类型,为Pig
需要实现Comparator接口的方法 int compare(object o1,object o2);
String.compareTo()用于字符串之间的比较
用于compareTo()只适用于字符串之间的比较,int之间的比较就要自己写,原理其实是一样的
以下是程序的main部分的代码及运行结果:
//前期声明部分
//排序代码部分
程序的代码下载:
http://yunpan.cn/QEXacsPINVs6y