Comparable & Comparator 都是用来实现集合中的排序的,只是 Comparable 是在集合内部定义的方法实现的排序,
Comparator 是在集合外部实现的排序,所以,如想实现排序,就需要在集合外定义 Comparator 接口的方法或在集合内实现 Comparable 接口的方法。
Comparable 是一个对象本身就已经支持自比较所需要实现的接口(如 String、Integer 自己就可以完成比较大小操作)而 Comparator 是一个专用的比较器,当这个对象不支持自比较或者自比较函数不能满足你的要求时,你可以写一个比较器来完成两个对象之间大小的比较。
可以说一个是自己完成比较,一个是外部程序实现比较的差别而已。
用 Comparator 是策略模式(strategy design pattern),就是不改变对象自身,而用一个策略对象(strategy object)来改变它的行为。
比如:你想对整数采用绝对值大小来排序,Integer 是不符合要求的,你不需要去修改 Integer 类(实际上你也不能这么做)去改变它的排序行为,只要使用一个实现了 Comparator 接口的对象来实现控制它的排序就行了。
Comparator 在java.util包中
Comparable 在java.lang包中
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}