String類下compareTo()與compare()方法比較

String類下compareTo()與compare()方法比較

從網(wǎng)站建設到定制行業(yè)解決方案,為提供網(wǎng)站設計制作、成都網(wǎng)站建設服務體系,各種行業(yè)企業(yè)客戶提供網(wǎng)站建設解決方案,助力業(yè)務快速發(fā)展。成都創(chuàng)新互聯(lián)將不斷加快創(chuàng)新步伐,提供優(yōu)質的建站服務。

這兩個方法經常搞混淆,現(xiàn)對其進行總結以加深記憶。

compareTo(Object o)方法是java.lang.Comparable<T>接口中的方法,
當需要對某個類的對象進行排序時,該類需要實現(xiàn)Comparable<T>接口的,
必須重寫public int compareTo(T o)方法,
比如MapReduce中Map函數(shù)和Reduce函數(shù)處理的 <key,value>,
其中需要根據(jù)key對鍵值對進行排序,所以,key實現(xiàn)了WritableComparable<T>接口,
實現(xiàn)這個接口可同時用于序列化和反序列化。
WritableComparable<T>接口(用于序列化和反序列化)是Writable接口和Comparable<T>接口的組合;
判斷字符串大小的依據(jù)是根據(jù)它們在字典中的順序決定的。
如果參數(shù)字符串等于此字符串,則返回 0 值;
如果按字典順序此字符串小于字符串參數(shù),則返回一個小于 0 的值;
如果按字典順序此字符串大于字符串參數(shù),則返回一個大于 0 的值。

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

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

首先,寫一個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,根據(jù)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());
    }
  }
}

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

當前名稱:String類下compareTo()與compare()方法比較
標題鏈接:http://muchs.cn/article46/pdpeeg.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供電子商務、小程序開發(fā)品牌網(wǎng)站設計、自適應網(wǎng)站、網(wǎng)站排名、域名注冊

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設