在Java中的Stream API里,sorted()方法默认情况下按自然顺序(正序)对元素进行排序。这意味着如果你使用无参数的sorted()方法,且流中的元素类型实现了Comparable接口,那么元素会按照其compareTo方法定义的方式被排序。
如果你想要进行倒序排序,你需要提供一个反向的Comparator。这可以通过Comparator接口中的reversed()方法来实现。
以下是两种排序方式的示例:
正序排序
java
List<Integer> numbers = Arrays.asList(3, 1, 4, 1, 5, 9);
List<Integer> sortedNumbers = numbers.stream()
.sorted() // 默认为正序排序
.collect(Collectors.toList());
// 结果: [1, 1, 3, 4, 5, 9]
倒序排序
java
List<Integer> sortedNumbersDesc = numbers.stream()
.sorted(Comparator.reverseOrder()) // 使用Comparator来指定倒序
.collect(Collectors.toList());
// 结果: [9, 5, 4, 3, 1, 1]
对于自定义类型,你可以像下面这样实现:
java
List<Person> people = ...; // 假设这是一个装有Person对象的列表
// 根据年龄进行正序排序
List<Person> sortedByAgeAscending = people.stream()
.sorted(Comparator.comparing(Person::getAge))
.collect(Collectors.toList());
// 根据年龄进行倒序排序
List<Person> sortedByAgeDescending = people.stream()
.sorted(Comparator.comparing(Person::getAge).reversed())
.collect(Collectors.toList());
在这个例子中,Comparator.comparing(Person::getAge) 创建了一个按年龄排序的比较器。通过链式调用reversed()方法,我们获得了该比较器的相反顺序,即按年龄的倒序排序。
Comparator接口还提供了其他方法,例如thenComparing,可以用来定义基于多个条件的排序策略,如果第一个比较器认为两个元素相等,可以使用thenComparing添加第二个比较器作为第二排序顺序。
在Java中的Stream API里,sorted()方法默认情况下按自然顺序(正序)对元素进行排序。
最新推荐文章于 2024-08-09 14:33:19 发布