public class Test
{
public static void main(String args[]) {
String foo = "ABC";
String bar01 = "ABC";
System.out.println(foo.compareTo(bar01));//前面和后面每个字符完全一样,返回 0
// 前面每个字符完全一样,返回:后面就是字符串长度差
String bar02 = "ABCD";
String bar03 = "ABCDE";
String bar06 = "AB";
System.out.println("与bar02比:"+foo.compareTo(bar02)); // -1 (前面相等,foo 长度小 1)
System.out.println("与bar03比:"+foo.compareTo(bar03)); // -2 (前面相等,foo 长度小 2)
System.out.println("与bar06比:"+foo.compareTo(bar06)); // 1 (前面相等,foo 长度大 1)
// 前面每个字符不完全一样,返回:出现不一样的字符 ASCII 差
String bar04 = "ABD";
String bar07 = "YZ";
String bar05 = "aABCD";
System.out.println("与bar04比:"+foo.compareTo(bar04)); // -1 (foo 的 'C' 字符 ASCII 码值为 67,bar04 的 'D' 字符 ASCII 码值为 68。返回 67 - 68 = -1)
System.out.println("与bar07比:"+foo.compareTo(bar07)); // -24 字符都不同,按照第一个字母的ASCII差值进行比较,A为65,Y为89。
System.out.println("与bar05比:"+foo.compareTo(bar05)); // -32 (foo 的 'A' 字符 ASCII 码值为 65,bar04 的 'a' 字符 ASCII 码值为 97。返回 65 - 97 = -32)
String bysocket01 = "泥瓦匠";
String bysocket02 = "瓦匠";
System.out.println(bysocket01.compareTo(bysocket02));// -2049 (泥 和 瓦的 Unicode 差值)
}
}
运行结果:
Comparator
可以认为是是一个外比较器,实现两个对象之间的比较。
public interface Comparator<T> {
int compareTo(T o1, T o2);
//省略...........
}
o1 < o2 ---- 返回负数
o1 = o2 ---- 返回 0
o1 > o2 ---- 返回正数
上面的代码可以看到,string
中的compareTo方法的比较
逻辑大概可以为:
字符串的每个字符完全一样,返回 0;
字符串前面部分的每个字符完全一样,返回:后面两个字符串长度差;
字符串前面部分的每个字符存在不一样,返回:出现不一样的字符 ASCII 码的差值。
在String内部还有个静态内部类CaseInsensitiveComparator
也实现了该接口
private static class CaseInsensitiveComparator
implements Comparator<String>, java.io.Serializable{
//......
}
该重写的接口方法是String
对象的大小写不敏感比较方法
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);
//还不一样则:返回不一样字符的ASCII 码的差值。
if (c1 != c2) {
// No overflow because of numeric promotion
return c1 - c2;
}
}
}
}
return n1 - n2;
}