下面来自jdk中src/java/lang下的String类的compareTo()方法源码,反斜线//后面的部分为个人注释
public int compareTo(String anotherString) {
int len1 = count; //当前字符串对象的长度
int len2 = anotherString.count; //当前参数字符串对象的长度
int n = Math.min(len1, len2); //设置最大比较次数n
char v1[] = value;
char v2[] = anotherString.value;
int i = offset; //当前字符串开始位置
int j = anotherString.offset; //当前参数字符串开始位置
if (i == j) { //如果当前对象和参数对象的开始位置相同
int k = i;
int lim = n + i;
while (k < lim) {
char c1 = v1[k];
char c2 = v2[k];
if (c1 != c2) {
return c1 - c2; //返回unicode值的差
}
k++;
}
} else {
while (n-- != 0) {
char c1 = v1[i++];
char c2 = v2[j++];
if (c1 != c2) {
return c1 - c2;
}
}
}
return len1 - len2; //当前n个字符都相同时,返回两个字符串的长度的差
}
关于上述代码有两点理解:
1.为什么判断i==j,是否为了少两次自增/自减操作(j++/n--)?
2.compareTo方法的实际应用场景。
compareTo来自于java.lang.Comparable接口,如同其API中方法的第一句注释说明:Compares the object with the specified object for order.可见此方法的目的实际为提供一种确定两个对象先后顺序的方法,这样需要我们去自定义何为“先”,何为“后”的概念(区别于Object类的equals方法,其目的为比较两个对象是否相同)。
规则可参照java.lang.Comparable接口原码的注释部分。