Comparable & Comparator 都是用來實現(xiàn)集合中元素的比較湘换、排序的,只是 Comparable 是在集合內(nèi)部定義的方法實現(xiàn)的排序站玄,Comparator 是在集合外部實現(xiàn)的排序谆沃,所以游盲,如想實現(xiàn)排序吨瞎,就需要在集合外定義 Comparator 接口的方法或在集合內(nèi)實現(xiàn) Comparable 接口的方法痹兜。
Comparator位于包Java.util下,而Comparable位于包 java.lang下
Comparable 是一個對象本身就已經(jīng)支持自比較所需要實現(xiàn)的接口(如 String关拒、Integer 自己就可以完成比較大小操作佃蚜,已經(jīng)實現(xiàn)了Comparable接口)
自定義的類要在加入list容器中后能夠排序庸娱,可以實現(xiàn)Comparable接口着绊,在用Collections類的sort方法排序時,如果不指定Comparator熟尉,那么就以自然順序排序归露,如API所說:
Sorts the specified list into ascending order, according to the natural ordering of its elements. All elements in the list must implement the Comparable interface
這里的自然順序就是實現(xiàn)Comparable接口設定的排序方式。
而 Comparator 是一個專用的比較器斤儿,當這個對象不支持自比較或者自比較函數(shù)不能滿足你的要求時剧包,你可以寫一個比較器來完成兩個對象之間大小的比較。
可以說一個是自已完成比較往果,一個是外部程序?qū)崿F(xiàn)比較的差別而已疆液。
用 Comparator 是策略模式(strategy design pattern),就是不改變對象自身陕贮,而用一個策略對象(strategy object)來改變它的行為堕油。
比如:你想對整數(shù)采用絕對值大小來排序,Integer 是不符合要求的肮之,你不需要去修改 Integer 類(實際上你也不能這么做)去改變它的排序行為掉缺,只要使用一個實現(xiàn)了 Comparator 接口的對象來實現(xiàn)控制它的排序就行了。
如果不是調(diào)用sort方法戈擒,相要直接比較兩個對象的大小眶明,如下:
Comparator定義了倆個方法,分別是 int compare(T o1, T o2)和 boolean equals(Object obj)筐高,
用于比較兩個Comparator是否相等
true only if the specified object is also a comparator and it imposes the same ordering as this comparator.
有時在實現(xiàn)Comparator接口時搜囱,并沒有實現(xiàn)equals方法丑瞧,可程序并沒有報錯,原因是實現(xiàn)該接口的類也是Object類的子類蜀肘,而Object類已經(jīng)實現(xiàn)了equals方法
Comparable接口只提供了 int compareTo(T o)方法嗦篱,也就是說假如我定義了一個Person類,這個類實現(xiàn)了 Comparable接口幌缝,那么當我實例化Person類的person1后灸促,我想比較person1和一個現(xiàn)有的Person對象person2的大小時,我就可以這樣來調(diào)用:person1.comparTo(person2),通過返回值就可以判斷了涵卵;而此時如果你定義了一個 PersonComparator(實現(xiàn)了Comparator接口)的話浴栽,那你就可以這樣:PersonComparator comparator= new PersonComparator();
comparator.compare(person1,person2);。
public class CompareTest {
public static void main(String[] args) {
CompareTest c = new CompareTest();
PersonComparator comparator = c.new PersonComparator();
Person p1 = c.new Person(11,"小明");
Person p2 = c.new Person(22, "小紅");
int compare = p1.compareTo(p2);
switch (compare) {
case 1:
System.out.println(p1.getName()+"的年紀比"+ p2.getName()+"大");
break;
case 0:
System.out.println(p1.getName()+"的年紀和"+ p2.getName()+"一樣大");
break;
default:
System.out.println(p1.getName()+"的年紀比"+ p2.getName()+"小");
}
compare = comparator.compare(p1, p2);
switch (compare) {
case 1:
System.out.println(p1.getName()+"的年紀比"+ p2.getName()+"大");
break;
case 0:
System.out.println(p1.getName()+"的年紀和"+ p2.getName()+"一樣大");
break;
default:
System.out.println(p1.getName()+"的年紀比"+ p2.getName()+"小");
}
}
class Person implements Comparable<Person>{
private int age;
private String name;
public Person(int age, String name) {
super();
this.age = age;
this.name = name;
}
@Override
public int compareTo(Person p) {
return this.age > p.getAge()? 1 : (this.age == p.getAge() ? 0 : -1);
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
class PersonComparator implements Comparator<Person>{
@Override
public int compare(Person p1, Person p2) {
return p1.getAge() > p2.getAge() ? 1 : (p1.getAge() == p2.getAge()?0:-1);
}
}
}