Java中字符串排序默认按字典序,使用compareTo方法或Arrays.sort()、Collections.sort()实现;可借助String.CASE_INSENSITIVE_ORDER忽略大小写,或通过Comparator自定义规则如按长度排序。

在Java中对字符串进行比较排序,通常使用的是 compareTo 方法或借助 Collections.sort()、Arrays.sort() 等工具。Java中的字符串默认按照字典序(lexicographic order)进行排序,这是基于Unicode值的字符逐个比较。
1. 使用 compareTo 进行字符串比较
String 类实现了 Comparable 接口,其 compareTo(String anotherString) 方法用于比较两个字符串:
- 返回 0:两个字符串相等
- 返回负数:当前字符串在字典序中排在前面
- 返回正数:当前字符串在字典序中排在后面
例如:
String a = "apple"; String b = "banana"; int result = a.compareTo(b); // 返回负数,因为 "apple" 在 "banana" 前面
2. 对字符串数组进行排序
使用 Arrays.sort() 可以直接对字符串数组进行升序排序:
String[] fruits = {"banana", "apple", "cherry"}; Arrays.sort(fruits); // 结果:["apple", "banana", "cherry"]
该方法默认按字典序升序排列,底层调用的就是每个字符串的 compareTo 方法。
立即学习“Java免费学习笔记(深入)”;
3. 对列表中的字符串排序
如果使用 ArrayList 或其他 List 实现,可以使用 Collections.sort():
List<String> words = Arrays.asList("java", "go", "python", "c"); Collections.sort(words); // 结果:["c", "go", "java", "python"]
4. 忽略大小写的排序
如果希望忽略大小写进行排序,可以使用 String.CASE_INSENSITIVE_ORDER 比较器:
String[] names = {"Alice", "bob", "Charlie", "alice"}; Arrays.sort(names, String.CASE_INSENSITIVE_ORDER); // 按忽略大小写排序
或者在列表中使用:
Collections.sort(words, String.CASE_INSENSITIVE_ORDER);
5. 自定义排序规则
如果需要自定义排序方式(比如按长度排序),可以使用 Lambda 表达式或实现 Comparator:
List<String> strings = Arrays.asList("a", "bb", "ccc", "dd"); strings.sort((s1, s2) -> Integer.compare(s1.length(), s2.length())); // 按字符串长度升序排序
基本上就这些常用方式。根据需求选择默认排序、忽略大小写或自定义规则即可。


