说我有一个我想过滤到每所学校中最老的组合。
到目前为止,我有:
Map<String, Long> getOldestPerSchool(Set<Person> persons) {
return persons.stream().collect(Collectors.toMap(Person::getSchoolname, Person::getAge, Long::max);
}
麻烦的是,我想要整个人,而不仅仅是名字。但是,如果我将其更改为:
Map<Person, Long> getOldestPerSchool(Set<Person> persons) {
return persons.stream().collect(Collectors.toMap(p -> p, Person::getAge, Long::max);
}
我得到了所有人,我不一定需要一张地图。
答案 0 :(得分:3)
设置我想过滤到每个学校中最古老的一个。
假设每所学校的历史最悠久意味着每Person
最古老的school
,您可能正在寻找类似以下的输出:
Map<String, Person> getOldestPersonPerSchool(Set<Person> persons) {
return persons.stream()
.collect(Collectors.toMap(
Person::getSchoolname, // school name
Function.identity(), // person
(a, b) -> a.getAge() > b.getAge() ? a : b)); // ensure to store oldest (no tie breaker for same age)
}
答案 1 :(得分:0)
您可以通过中间分组来实现此目的,然后仅在结果分组列表的values()
上流式传输,就可以选择最年长的人
Set<Person> oldestPerSchool = persons.stream() // Stream<Person>
.collect(Collectors.groupingBy(Person::getSchoolname)) // Map<String, List<Person>>
.values().stream() // Stream<List<Person>>
.map(list -> list.stream() // (Inner) Stream<Person>
.max(Comparator.comparingInt(Person::getAge)) // (Inner) Optional<Person>
.get() // (Inner) Person
) // Stream<Person>
.collect(Collectors.toSet()); // Set<Person>