Java——String類中的compareTo方法總結

String類的定義:java

   java.lang
 類 String
數組

  java.lang.Object
      java.lang.Stringless


全部已實現的接口:
Serializable, CharSequence, Comparable<String>
 this

public final class String
      extends Objectimplements Serializable, Comparable<String>, CharSequence
String 類表明字符串。Java 程序中的全部字符串字面值(如 "abc" )都做爲此類的實例實現。spa

字符串是常量;它們的值在建立以後不能更改。字符串緩衝區支持可變的字符串。由於 String 對象是不可變的,因此能夠共享。.net

例如:code

     String str = "abc";
 

等效於:對象

     char data[] = {'a', 'b', 'c'};
     String str = new String(data);

再來看看String類中的compareTo方法:blog

具體解釋以下:排序

compareTo
public int compareTo(String anotherString)
按字典順序比較兩個字符串。該比較基於字符串中各個字符的 Unicode 值。按字典順序將此 String 對象表示的字符序列與參數字符串所表示的字符序列進行比較。若是按字典順序此 String 對象位於參數字符串以前,則比較結果爲一個負整數。若是按字典順序此 String 對象位於參數字符串以後,則比較結果爲一個正整數。若是這兩個字符串相等,則結果爲 0;compareTo 只在方法 equals(Object) 返回 true 時才返回 0。
這是字典排序的定義。若是這兩個字符串不一樣,那麼它們要麼在某個索引處的字符不一樣(該索引對兩者均爲有效索引),要麼長度不一樣,或者同時具有這兩種狀況。若是它們在一個或多個索引位置上的字符不一樣,假設 k 是這類索引的最小值;則在位置 k 上具備較小值的那個字符串(使用 < 運算符肯定),其字典順序在其餘字符串以前。在這種狀況下,compareTo 返回這兩個字符串在位置 k 處兩個char 值的差,即值:

this.charAt(k)-anotherString.charAt(k)

 

若是沒有字符不一樣的索引位置,則較短字符串的字典順序在較長字符串以前。在這種狀況下,compareTo 返回這兩個字符串長度的差,即值:
this.length()-anotherString.length()

this.charAt(k)-anotherString.charAt(k)

 

指定者:
接口 Comparable<String> 中的 compareTo
參數
anotherString - 要比較的 String。
返回
若是參數字符串等於此字符串,則返回值 0;若是此字符串按字典順序小於字符串參數,則返回一個小於 0 的值;若是此字符串按字典順序大於字符串參數,則返回一個大於 0 的值。

 N多的類中都有該compareTo方法,根本緣由是由於它們都實現了接口comparable接口,而且實現了接口中的compareTo方法。

以下所示:

 

public interface Comparable<T>
此接口強行對實現它的每一個類的對象進行總體排序。這種排序被稱爲類的天然排序,類的 compareTo 方法被稱爲它的天然比較方法。

實現此接口的對象列表(和數組)能夠經過 Collections.sort(和 Arrays.sort)進行自動排序。實現此接口的對象能夠用做有序映射中的鍵或有序集合中的元素,無需指定比較器。

對於類 C 的每個 e1 和 e2 來講,當且僅當 e1.compareTo(e2) == 0 與 e1.equals(e2) 具備相同的 boolean 值時,類 C 的天然排序才叫作與 equals 一致。注意,null 不是任何類的實例,即便 e.equals(null) 返回 false,e.compareTo(null) 也將拋出 NullPointerException。

實際上,全部實現 Comparable 的 Java 核心類都具備與 equals 一致的天然排序。java.math.BigDecimal 是個例外,它的天然排序將值相等但精確度不一樣的 BigDecimal 對象(好比 4.0 和 4.00)視爲相等。

 

 說了這麼多,咱們來看一下String類中是如何實現compareTo方法的:

 1     /* @param   anotherString   the <code>String</code> to be compared.
 2      * @return  the value <code>0</code> if the argument string is equal to
 3      *          this string; a value less than <code>0</code> if this string
 4      *          is lexicographically less than the string argument; and a
 5      *          value greater than <code>0</code> if this string is
 6      *          lexicographically greater than the string argument.
 7      */
 8     public int compareTo(String anotherString) {
 9         int len1 = value.length;
10         int len2 = anotherString.value.length;
11         int lim = Math.min(len1, len2);
12         char v1[] = value;
13         char v2[] = anotherString.value;
14  
15         int k = 0;
16         while (k < lim) {
17             char c1 = v1[k];
18             char c2 = v2[k];
19             if (c1 != c2) {
20                 return c1 - c2;
21             }
22             k++;
23         }
24         return len1 - len2;
25     }

 

 由源碼能夠看出:

     首先取出兩個字符串的長度,比較較小的長度內,二者是否相等。

          若不相等,則直接返回該位置字符的ASCII碼相減後的值。

          若各位置都相等,則將兩個字符串長度的差值返回。

原文:https://blog.csdn.net/qq_25827845/article/details/53870329

相關文章
相關標籤/搜索