初學(xué)者一枚,今天使用字符串的compareTo方法的時(shí)候,想知道原理,就翻了翻源碼。
/*
*如果參數(shù)字符串等于此字符串,則返回值 0;
*如果此字符串按字典順序小于字符串參數(shù),則*返回一個(gè)小于 0 的值;
*如果此字符串按字典順序大于字符串參數(shù),則返回一個(gè)大于 0 的值。
*/
private final char value[];
public int compareTo(String anotherString) {
int len1 = value.length;
int len2 = anotherString.value.length;
//取數(shù)組長(zhǎng)度里面最小的
int lim = Math.min(len1, len2);
// 獲得兩個(gè)數(shù)組,這兩個(gè)數(shù)組就是string的屬性
char v1[] = value;
char v2[] = anotherString.value;
int k = 0;
while (k < lim) {
//獲取第K的字符,進(jìn)行比較
char c1 = v1[k];
char c2 = v2[k];
if (c1 != c2) {
//Java使用的是Unicode編碼,因此返回這兩個(gè)字符的Unicode差值。
return c1 - c2;
}
k++;
}
//如果前l(fā)im個(gè)字符都相同,那么就返回長(zhǎng)度差。
return len1 - len2;
}
其實(shí)就是:
1、取得string的value數(shù)組
2、取得value數(shù)組里面的元素
3、按照unicode值進(jìn)行比較
4、返回比較的值