这种情况是针对全部是数值型字符串的比较。适用场景:数值型字符串,因为0-9对应的ASCII码数值是48-57,是同比增加的。
public static void main(String[] args) {
String zhangsAge = "22";
String lisiAge = "44";
int result = zhangsAge.compareTo(lisiAge);
System.out.println("数值型字符串比较,若是result结果小于0,则张三的年龄小于李四的年龄" + result);
}

因为String实现了Comparable接口,可以使用自定义判断特殊的字符串比较并排序
public static void main(String[] args) {
String[] arr = {"2", "0", "7", "4", "10", "18", "9"};
List<String> list = Arrays.asList(arr);
Collections.sort(list, new Comparator<String>() {
@Override
public int compare(String s1, String s2) {
int i1 = Integer.parseInt(s1);
int i2 = Integer.parseInt(s2);
return i1 - i2;
}
});
System.out.println(list);
// 输出结果为:[0, 2, 4, 7, 9, 10, 18],达到了排序效果
}

适用于相同结构类型的数值型字符串,比如格式为yyyy-MM-dd的字符串日期的比较
public static void main(String[] args) {
String dt1 = "2021-09-12";
String dt2 = "2022-09-12";
int result = dt2.compareTo(dt1);
System.out.println("相同结构类型的数值型字符串比较,因为dt2的日期大于dt1的日期,所以result大于0,result = " + result);
}

// String中compareTo方法源码
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) {// 这里是重点,意思是将字符串拆分成多个字符,比较字符在ASCII码中的数值大小
return c1 - c2;
}
k++;
}
return len1 - len2;
}
