stream流根据list中的两个字段进行排序
时间: 2023-09-19 11:10:12 浏览: 61
可以使用Java 8的流API来根据list中的两个字段进行排序。假设我们有一个包含Person对象的List,每个Person对象有两个属性:姓名和年龄。
首先,我们需要为Person对象创建一个Comparator,它将首先按照姓名进行排序,如果姓名相同,则按照年龄进行排序:
```
Comparator<Person> comparator = Comparator.comparing(Person::getName)
.thenComparingInt(Person::getAge);
```
然后,我们可以使用流API对List进行排序:
```
List<Person> sortedList = personList.stream()
.sorted(comparator)
.collect(Collectors.toList());
```
这将返回一个按照姓名和年龄排序的新List。
相关问题
java list使用流根据2个字段排序
可以使用Java 8的流(Stream)和Comparator来根据两个字段排序List。假设List中的元素类型为Person,包含两个字段name和age,可以按照以下方式进行排序:
```
List<Person> personList = new ArrayList<>();
// 添加元素到personList中
personList.sort(Comparator.comparing(Person::getName).thenComparing(Person::getAge));
```
这个例子中,我们先按照name字段进行排序,然后按照age字段进行排序。其中,Comparator.comparing()方法用于按照指定字段进行排序,thenComparing()方法用于在已有排序基础上按照另一个字段进行排序。注意,这种方式会修改原List的顺序,如果不想修改原List,可以使用sorted()方法创建一个新的排序后的List。
stream流按两个字段排序_如何在Java中按两个字段排序?
在Java中使用stream流按两个字段排序可以使用Comparator.comparing()和thenComparing()方法来实现。
下面是一个按两个字段排序的示例代码:
```java
public class Person {
private String name;
private int age;
public Person(String name, int age) {
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public int getAge() {
return age;
}
}
public class Main {
public static void main(String[] args) {
List<Person> people = new ArrayList<>();
people.add(new Person("Alice", 25));
people.add(new Person("Bob", 30));
people.add(new Person("Alice", 20));
people.add(new Person("Bob", 25));
List<Person> sortedPeople = people.stream()
.sorted(Comparator.comparing(Person::getName).thenComparing(Person::getAge))
.collect(Collectors.toList());
for (Person p : sortedPeople) {
System.out.println(p.getName() + " " + p.getAge());
}
}
}
```
输出结果:
```
Alice 20
Alice 25
Bob 25
Bob 30
```
在上面的示例代码中,我们先定义了一个Person类。然后我们在main()方法中先创建了一个包含4个Person对象的people列表。
我们使用stream()方法将people列表转换为一个stream流,并使用sorted()方法对流进行排序。在sorted()方法中,我们使用Comparator.comparing()方法按照name字段进行排序,如果name相同,再使用thenComparing()方法按照age字段进行排序。最后使用collect()方法将排序后的流转换为一个列表。
最后我们遍历输出排序后的结果。
需要注意的是,使用stream流排序可能会产生一些额外的开销,因为它需要额外的计算和内存。因此,如果数据量很大,可能需要考虑使用其他的排序方法。