這兩個方法經常搞混淆,現對其進行總結以加深記憶。
- compareTo(Object o)方法是java.lang.Comparable接口中的方法,當需要對某個類的對象進行排序時,該類需要實現Comparable接口的,必須重寫public int compareTo(T o)方法,比如MapReduce中Map函數和Reduce函數處理的 ,其中需要根據key對鍵值對進行排序,所以,key實現了WritableComparable接口,實現這個接口可同時用於序列化和反序列化。WritableComparable接口(用於序列化和反序列化)是Writable接口和Comparable接口的組合;
- compare(Object o1,Object o2)方法是java.util.Comparator接口的方法,它實際上用的是待比較對象的compareTo(Object o)方法。
下面我們寫一來看看上面兩個方法是怎么用的:
首先,寫一個User類,代碼如下:
public class User implements Comparable {
int id;
String name;
public User(int id, String name) {
this.id = id;
this.name = name;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public int compareTo(Object o) {
if (this == o) {
return 0;
} else if (o != null && o instanceof User) {
User u = (User) o;
if (id <= u.id) {
return -1;
} else {
return 1;
}
} else {
return -1;
}
}
}
接下來,我們寫一個測試類Test:
public class Test{ //編寫Comparator,根據User的id對User進行排序 private static final Comparator COMPARATOR = new Comparator() { public int compare(User o1, User o2) { return o1.compareTo(o2);//運用User類的compareTo方法比較兩個對象 } }; public static void main(String[] args) { ArrayList student = new ArrayList(); User user1 = new User(1,"yueliming"); User user2 = new User(2,"yueliming"); Collections.sort(student, COMPARATOR);//用我們寫好的Comparator對student進行排序 for(int i=0;i){ System.out.println(student.get(i).getId()); } } }