相同点:1)他们都可以用来实现集合的排序
2)他们都是接口。
区别:1) Comparable用在集合内部排序,Comparator用在集合外排序。什么意思呢? 就是比如说TreeSet实现定制排序,排序的实体类要实现Comparable接口,加 入一个元素,TreeSet就会使用该实体类进行排序,然后插入到集合中。该实体类 实现Comparable接口的compareTo(Object o)方法,只有一个参数,是自比较。
而Comparator接口下的实现类实现compare(Object o1,Object o2)方法,有2个参数, 可以作为一种特殊的比较器,相当于一个工具类在Arrays.sort(T[]a,Comparatorc),Collections.sort(List<T> list,Comparator c)方法中,传入比较器,该集合工具调用比较器来排序.我个人认为是一种回调模式。
2)java.util.Comparable
java.lang.comparable