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;
1.. 首先获得 str1 和str2的长度 length1 和length2 然后获得min 最小的那个长度值 length1
2.. 定义一个 k=0 ,将String内容放进 char[]数组 while(k<length1) 不断比较char1[k] != char2[k]
如果所在元素满足 则 返回ASC码值 的差值 return c1-c2
比如 apple 和banna 第一个元素 a ASC码值 97
b是 98 第一次比较就不相等返回 97-98 =-1
若 apple 和app 比较3次元素相等后 就返回字符串长度 差5-3= 2