这个方法的意思是比较两个字符串,不区分大小写。
我们来看一下这个方法是怎样实现的?
public int compareToIgnoreCase(String str) {
return CASE_INSENSITIVE_ORDER.compare(this, str);
}
它通过一个引用调用一个方法,并将这个要比较的字符串和当前类的String对象传过来。
让我们来看以下这个引用是哪个类的实例?
public static final Comparator<String> CASE_INSENSITIVE_ORDER = new CaseInsensitiveComparator();
我们发现CaseInsensitiveComparator这个类,是String类中的静态内部类。它实现了comparetor接口,实现了它的compare()方法。
我们来看一下这个compare()方法。
public int compare(String s1, String s2) {
int n1 = s1.length();
int n2 = s2.length();
int min = Math.min(n1, n2);
for (int i = 0; i < min; i++) {
char c1 = s1.charAt(i);
char c2 = s2.charAt(i);
if (c1 != c2) {
c1 = Character.toUpperCase(c1);
c2 = Character.toUpperCase(c2);
if (c1 != c2) {
c1 = Character.toLowerCase(c1);
c2 = Character.toLowerCase(c2);
if (c1 != c2) {
// No overflow because of numeric promotion
return c1 - c2;
}
}
}
}
return n1 - n2;
}
显然,比较的方法是这样的,找到两个字符串的长度最小的那个,记为min,作为for循环的次数,比较他们两个的前min的char,如果不相同就全都转换成大写,如何还不相同,就全部都转换成小写,如果还不相同的话,就直接返回。
我们来继续看conpareTo方法。
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;
}
比较两个字符串的长度,如果二者相等,返回0,如果不相等,如下例子,返回str2-str1。
下面是例子。
String str1 = "Stringtest";
System.out.println("compareTo方法"+str1.compareTo("test"));
运行结果
compareTo方法-1