亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java compare compareTo方法區(qū)別詳解

 更新時(shí)間:2021年09月16日 09:52:26   作者:會(huì)飛的魚干干  
本文主要介紹了java compare compareTo方法區(qū)別,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

1,compareTo(Object o)方法是java.lang.Comparable<T>接口中的方法,當(dāng)需要對(duì)某個(gè)類的對(duì)象進(jìn)行排序時(shí),該類需要實(shí)現(xiàn)Comparable<T>接口的,必須重寫public int compareTo (T o)方法,比如MapReduce中Map函數(shù)和Reduce函數(shù)處理的<key,value>,其中需要根據(jù)key對(duì)鍵值對(duì)進(jìn)行排序,所以,key實(shí)現(xiàn)了WritableComparable<T>接口,實(shí)現(xiàn)這個(gè)接口可同時(shí)用于序列化和反序列化。WritableComparable<T>接口(用于序列化和反序列化)是Writable接口和Comparable<T>接口的組合;

2,compare(Object o1,Object o2)方法是java.util.Comparator<T>接口的方法,它實(shí)際上用的是待比較對(duì)象的compareTo(Object o)方法。

compareTo

  • compareTo(Object o)方法是java.lang.Comparable<T>接口中的方法,當(dāng)需要對(duì)某個(gè)類的對(duì)象進(jìn)行排序時(shí),該類需要實(shí)現(xiàn)Comparable<T>接口的,必須重寫public int compareTo(T o)方法。
  • 它強(qiáng)行將實(shí)現(xiàn)它的每一個(gè)類的對(duì)象進(jìn)行整體排序-----稱為該類的自然排序,實(shí)現(xiàn)此接口的對(duì)象列表和數(shù)組可以用Collections.sort(),和Arrays.sort()進(jìn)行自動(dòng)排序;
  • 也就是說,只要實(shí)現(xiàn)了這個(gè)接口的對(duì)象(數(shù)組)就相當(dāng)于有了排序的能力,所以叫做comparable---可排序的,所以可以說這是一種內(nèi)部排序的方式,通過實(shí)現(xiàn)它唯一的方法compareTo()。
  • 比如Hadoop中的MapReduce,Map函數(shù)和Reduce函數(shù)處理的 <key,value>,其中需要根據(jù)key對(duì)鍵值對(duì)進(jìn)行排序,所以,key實(shí)現(xiàn)了WritableComparable<T>接口,實(shí)現(xiàn)這個(gè)接口可同時(shí)用于序列化和反序列化。WritableComparable<T>接口(用于序列化和反序列化)是Writable接口和Comparable<T>接口的組合;

compare

  • compare(Object o1,Object o2)方法是java.util.Comparator<T>接口的方法,它實(shí)際上用的是待比較對(duì)象的compareTo(Object o)方法。
  • 對(duì)于它,則是針對(duì)一些本身沒有比較能力的對(duì)象(數(shù)組)為它們實(shí)現(xiàn)比較的功能,所以它叫做比較器,是一個(gè)外部的東西,通過它定義比較的方式,再傳到Collection.sort()和Arrays.sort()中對(duì)目標(biāo)排序,而且通過自身的方法compare()定義比較的內(nèi)容和結(jié)果的升降序;

下面我們寫一來看看上面兩個(gè)方法是怎么用的:

首先,寫一個(gè)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;
    }
}
}

接下來,我們寫一個(gè)測(cè)試類Test:

public class Test{
    //編寫Comparator,根據(jù)User的id對(duì)User進(jìn)行排序
    private static final Comparator<User> COMPARATOR = new Comparator<User>() {
       public int compare(User o1, User o2) {
           return o1.compareTo(o2);//運(yùn)用User類的compareTo方法比較兩個(gè)對(duì)象       
      }
   };
 
    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對(duì)student進(jìn)行排序
        for(int i=0;i<student.size();i++){
            System.out.println(student.get(i).getId());
        }
    }
}

總結(jié):Comparable<Object> 是一個(gè)接口,里面有一個(gè)排序的方法 compareTo(Object o){},要使得某個(gè)對(duì)象是可以排序的,那么這個(gè)對(duì)象必須必須實(shí)現(xiàn)這個(gè)接口,因?yàn)閮蓚€(gè)對(duì)象之間的排序,調(diào)用調(diào)用的比較方法,就是compareTo()方法。

Comparator<T>接口,是一個(gè)接口,里面的方法是compare(o1,o2) 它可以對(duì)o1,o2進(jìn)行排序,在這里面你就可以調(diào)用o1對(duì)象的compareTo方法排序了。

到此這篇關(guān)于java compare compareTo方法區(qū)別詳解的文章就介紹到這了,更多相關(guān)java compare compareTo內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論