Comparable & Comparator 都是用来实现集合中的排序的,只是 Comparable 是在集合内部定义的方法实现的排序, Comparator 是在集合外部实现的排序,所以,如想实现排序,就需要在集合外定义 Comparator 接口的方法或在集合内实现 Comparable 接口的方法。 Comparable 是一个对象本身就已经支持自比较所需要实现的接口(如 String、Integer 自己就可以完成比较大小操作) 而 Comparator 是一个专用的比较器,当这个对象不支持自比较或者自比较函数不能满足你的要求时,你可以写一个比较器来完成两个对象之间大小的比较。 可以说一个是自己完成比较,一个是外部程序实现比较的差别而已。 用 Comparator 是策略模式(strategy design pattern),就是不改变对象自身,而用一个策略对象(strategy object)来改变它的行为。 比如:你想对整数采用绝对值大小来排序,Integer 是不符合要求的,你不需要去修改 Integer 类(实际上你也不能这么做)去改变它的排序行为,只要使用一个实现了 Comparator 接口的对象来实现控制它的排序就行了。
1public class TestComparator {
2 AsComparator cl=new AsComparator(); 3 /** 4 * @param args 5 */ 6 @SuppressWarnings("unchecked") 7 public static void main(String[] args) { 8 Integer[] datas=new Integer[20]; 9 Random rand=new Random(); 10 for(int i=0;i<20;i++){ 11 datas[i]=new Integer(rand.nextInt(100)); 12 } 13 Arrays.sort(datas); 14 System.out.println(Arrays.asList(datas)); 15 TestComparator test=new TestComparator(); 16 Arrays.sort(datas,test.cl); 17 System.out.println(Arrays.asList(datas)); 18 19 } 20 21 @SuppressWarnings("rawtypes") 22 class AsComparator implements Comparator{ 23 24 public int compare(Object o1, Object o2) { 25 int value1= Math.abs(((Integer)o1).intValue()); 26 int value2=Math.abs(((Integer)o2).intValue()); 27 return value1>value2?1:(value1==value2?0:-1); 28 } 29 30 } 31 32 33} 34 |
|