本文旨在解决 Java 中使用 `toString()` 方法对集合进行排序时遇到的问题。通常,直接对集合转换成的数组进行排序不会影响原始集合的顺序。本文将介绍如何正确地对 `List` 集合进行排序,并提供示例代码和注意事项,帮助开发者避免类似问题。
在 Java 中,直接使用 Arrays.sort() 对集合转换成的数组进行排序,并不能改变原始集合的顺序。这是因为 Arrays.sort() 只是对数组进行了排序,而集合本身并没有发生改变。为了正确地对集合进行排序,需要使用 Collections.sort() 方法,并确保集合类型为 List。
问题分析
原始代码的问题在于:
解决方案
正确的做法是直接对 List 集合进行排序。下面是修改后的代码:
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
class Person {
private String privateName;
private String lastName;
public Person(String privateName, String lastName) {
this.privateName = privateName;
this.lastName = lastName;
}
@Override
public String toString() {
return privateName + " " + lastName;
}
}
class Main {
public static void main(String[] args) {
List people = new ArrayList<>();
people.add(new Person("aaa", "hhh"));
people.add(new Person("aaa", "aaa"));
people.add(new Person("aaa", "uuu"));
Collections.sort(people, Comparator.comparing(Person::toString));
System.out.println(people);
}
} 代码解释
运行结果
运行上述代码,输出结果如下:
[aaa aaa, aaa hhh, aaa uuu]
可以看到,Person 对象按照 toString() 方法的返回值进行了正确的排序。
注意事项
t。总结
当需要对 Java 集合进行排序时,应使用 Collections.sort() 方法直接对 List 进行排序,而不是先将其转换为数组再排序。使用 Comparator.comparing() 可以方便地指定排序的依据,从而实现自定义的排序逻辑。理解这些要点可以帮助开发者避免在集合排序时遇到的常见问题。