您的位置:首页 > 编程语言 > Java开发

Java.util.Collections.sort(List l) 排序 [implements Comparator]

2013-05-14 18:47 537 查看
implements Comparator的方法和implements Comparable的方法相比:前者能使一个类有多种可以排序的方法,例如,Pig类可以写一种按照name排序的方法的同时,又可以有按照体重进行排序的方法。
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类:



※仍然是要覆盖toString()方法※

用Comparator接口来写两个有指示排序功能的类:
注意,这里我是把两个关于Pig类的排序类写在了Pig类的外部,为的是省事。

更加结构化的方法是:把两个关于Pig类的排序类写在Pig内部,作为内部类。
可是这也带来个问题,每次创建排序类的实例时都要在之前创建个Pig类实例,其实不太符合逻辑。

下面是class NameSort的代码:
需要implements Comparator<T> T限定类型,为Pig
需要实现Comparator接口的方法 int compare(object o1,object o2);
String.compareTo()用于字符串之间的比较



下面是class WeightSort的代码:
用于compareTo()只适用于字符串之间的比较,int之间的比较就要自己写,原理其实是一样的



同样的,降序只要在compare()把两者倒过来,不赘述

以下是程序的main部分的代码及运行结果:



//前期声明部分



//排序代码部分

程序的代码下载:http://yunpan.cn/QEXacsPINVs6y
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: