Comparable 与 Comparator
version:1.8
在上一篇中我们看到TreeMap在进行值的比较的时候考虑了两种方式:Comparable 与 Comparator,在这里对其进行下比较。
Comparable
package java.lang;
public interface Comparable<T> {
public int compareTo(T o);
}
Comparable是位于java.lang包下的一个接口,内部只有一个方法public int compareTo(T o);
由于Java没有提供运算符重载的功能,为了实现类对象的大小比较,提供了该接口,类继承该接口,实现该方法以定义自己对象的大小比较的规则。
Comparator
package java.util;
public interface Comparator<T> {
int compare(T o1, T o2);
…………
}
Comparator是位于java.util包下的一个接口,内部定义多个方法,但最常用的还是与Comparable 对应的int compare(T o1, T o2);
从方法的定义看,Comparable是一个类的一个对象主动“挑战”另一个对象,两者根据类提前定好的规则比较胜负;Comparator 更像一个“裁判”,根据自身得到的规则对类的两个对象进行比较。
Comparable更多的体现了继承的思想,Comparator更多的体现了组合的思想。
平时对两者的一个常见的应用是在排序时,排序算法已经写好,但传入相反的Comparator可实现升序排序与降序排序。