java中compareTo和compare方法之比較

 

這兩個方法常常搞混淆,現對其進行總結以加深記憶。java

  1. compareTo(Object o)方法是java.lang.Comparable<T>接口中的方法,當須要對某個類的對象進行排序時,該類須要實現Comparable<T>接口的,必須重寫public int compareTo(T o)方法,好比MapReduce中Map函數和Reduce函數處理的 <key,value>,其中須要根據key對鍵值對進行排序,因此,key實現了WritableComparable<T>接口,實現這個接口可同時用於序列化和反序列化。WritableComparable<T>接口(用於序列化和反序列化)是Writable接口和Comparable<T>接口的組合;
  2. compare(Object o1,Object o2)方法是java.util.Comparator<T>接口的方法,它實際上用的是待比較對象的compareTo(Object o)方法。

下面咱們寫一來看看上面兩個方法是怎麼用的:ide

首先,寫一個User類,代碼以下:函數

複製代碼

public class User implements Comparable<Object>{
    int id;
    String name;
    
    public User(int id,String name){
        this.id = id;
        this.name = name;
    }
    /*
     * Getters and Setters
    */
    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<User> COMPARATOR = new Comparator<User>() {
       public int compare(User o1, User o2) {
           return o1.compareTo(o2);//運用User類的compareTo方法比較兩個對象       
      }
   };
    
    public static void main(String[] args) {
        ArrayList<User> student = new ArrayList<User>();
        User user1 = new User(1,"yueliming");
        User user2 = new User(2,"yueliming");
    
        Collections.sort(student, COMPARATOR);//用咱們寫好的Comparator對student進行排序
        for(int i=0;i<student.size();i++){
            System.out.println(student.get(i).getId());
        }
    }
}
相關文章
相關標籤/搜索