Java 集合排序:Collections.sort() 方法详解
Collections.sort()
是 Java 集合框架中的一个静态方法,用于对 List 集合进行排序。该方法有多个重载版本,可以根据需要对自定义对象进行排序。
解决方案1:对于简单的数据类型,如 Integer,Double 等,可以直接使用 Collections.sort()
进行排序。
List<Integer> numbers = new ArrayList<Integer>();
numbers.add(3);
numbers.add(1);
numbers.add(4);
numbers.add(1);
Collections.sort(numbers);
System.out.println(numbers); // 输出 [1, 1, 3, 4]
解决方案2:对于自定义对象,需要提供一个 Comparator 对象来指导排序。
class Person {
String name;
int age;
// getters and setters
}
List<Person> people = new ArrayList<Person>();
people.add(new Person("John", 40));
people.add(new Person("Alice", 25));
people.add(new Person("Bob", 20));
Collections.sort(people, new Comparator<Person>() {
public int compare(Person p1, Person p2) {
return p1.getName().compareTo(p2.getName());
}
});
// 或者使用 lambda 表达式简化
Collections.sort(people, (p1, p2) -> p1.getName().compareTo(p2.getName()));
解决方案3:如果需要对 List 进行逆序排序,可以使用 Comparator
接口的 reversed()
方法。
Collections.sort(people, Collections.reverseOrder());
// 或者
Collections.sort(people, (p1, p2) -> p2.getName().compareTo(p1.getName()));
解决方案4:从 Java 8 开始,可以使用 lambda 表达式或方法引用来简化代码。
Collections.sort(people, (p1, p2) -> Integer.compare(p1.getAge(), p2.getAge()));
// 或者
Collections.sort(people, Comparator.comparingInt(Person::getAge));
以上是 Collections.sort()
方法的几种常见用法,可以根据实际需求选择合适的方法进行使用。
评论已关闭