Stream流toMap,key相同Value取最大值
示例代码1
package com.company;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.stream.Collectors;
public class test6 {
public static void main(String[] args) {
Employee employee = new Employee(15, "18801171255", "man", 1);
Employee employee1 = new Employee(18, "18801171255", "woman", 2);
Employee employee2 = new Employee(20, "18801171255", "man", 3);
Employee employee3 = new Employee(20, "18801171255", "man", 5);
List<Employee> list = new ArrayList<>();
list.add(employee);
list.add(employee1);
list.add(employee2);
list.add(employee3);
Map<Integer, Integer> map = list.stream().collect(Collectors.toMap(Employee::getAge, item -> item.getSalary(), Math::max));
Set<Map.Entry<Integer, Integer>> en = map.entrySet();
for (Map.Entry<Integer, Integer> e : en) {
System.out.println(e.getKey() + ":" + e.getValue());
}
}
}
result: 18:2
20:5
15:1
![在这里插入图片描述](https://i-blog.csdnimg.cn/blog_migrate/2b0aed5642075517145142e573391b9c.png)
示例代码2
LambdaQueryWrapper<ProjectStudentSummaryEntity> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.in(ProjectStudentSummaryEntity::getUserId, studentUserIdList);
Map<String, Integer> userIdAnd = projectStudentSummaryDao.listByConds(queryWrapper).stream()
.collect(Collectors.toMap(ProjectStudentSummaryEntity::getUserId,
entity -> JSONObject.parseObject(entity.getProjectSummary(), ProjectBo.class).getSections().size(),Math::max));