
本文旨在解决 Java 中使用 `toString()` 方法对集合进行排序时遇到的问题。通常,直接对集合转换成的数组进行排序不会影响原始集合的顺序。本文将介绍如何正确地对 `List` 集合进行排序,并提供示例代码和注意事项,帮助开发者避免类似问题。
在 Java 中,直接使用 Arrays.sort() 对集合转换成的数组进行排序,并不能改变原始集合的顺序。这是因为 Arrays.sort() 只是对数组进行了排序,而集合本身并没有发生改变。为了正确地对集合进行排序,需要使用 Collections.sort() 方法,并确保集合类型为 List。
问题分析
原始代码的问题在于:
立即学习“Java免费学习笔记(深入)”;
解决方案
正确的做法是直接对 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<Person> 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() 方法的返回值进行了正确的排序。
注意事项
总结
当需要对 Java 集合进行排序时,应使用 Collections.sort() 方法直接对 List 进行排序,而不是先将其转换为数组再排序。使用 Comparator.comparing() 可以方便地指定排序的依据,从而实现自定义的排序逻辑。理解这些要点可以帮助开发者避免在集合排序时遇到的常见问题。
以上就是Java:使用 toString 方法排序集合不起作用的解决方案的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号