以下是JDK类库中java.lang.String类的compareTo(java.lang.String)方法源码(注释为自己加的)
public int compareTo(String anotherString) {
int len1 = value.length;//获取原字符串的长度
int len2 = anotherString.value.length;//获取被比较字符串的长度
int lim = Math.min(len1, len2);//取两个字符串长度的最小值
char v1[] = value;
char v2[] = anotherString.value;
int k = 0;
while (k < lim) {
char c1 = v1[k];
char c2 = v2[k];
if (c1 != c2) {
return c1 - c2;
}
k++;
}
return len1 - len2;
}
由源码可以看出,字符串的比较规则是:假设存在字符串str1和str2,(1)首先将str1和str2两个字符串最高位的ASCII码值相减,如果结果大于0,则str1>str2;如果结果小于0,则str1<str2;如果结果等于零,则分别取str1和str2的下一位字符,按之前的规则进行比较,直到比较出结果,或者str1和str2中的一个所包含的所有字符均被比较,即str1和str2中的一个是另一个的开始部分。这时,再比较两个字符串的长度,将长度比较结果作为字符串大小的比较结果。