当可以接触到类的源码时,实现Comparable接口,重写public int compareTo(T o)函数。
这可以使类本身变得可比较(comparable), 可以用Collections.sort()排序,可以当map的key。
当不可接触到类的源码时,又想对类进行排序,可以实现Comparator接口。它是一个比较器,指导Collections.sort()等方法对对象排序。
这时需要实现 int compare (T o1, T o2)。实现后我们可以将Comparator传递给Collections.sort(),指导其排序。但类本身仍然是不可排序的,不可充当map的键。
由此可见,Comparable接口相当于内部排序器,使类本身变得可以排序。
而,Comparator接口相当于外部排序器,只是外部指导类如何排序,类本身仍然不可排序。
Comparator使排序有了更大的灵活性。