繁体   English   中英

如何限制groupBy java流

[英]How to limit in groupBy java stream

这是我课程中名为Course课程模型:

public class Course{
    private int courseId;
    private String courseName;
    private Teacher teacher;
}

这是我在班级Teacher老师模型:

public class Teacher{
    private int teacherId;
    private String name;
}

我想获得一个Map<String, List<Course>>但是如果要重复teacherId ,只需将该Course添加到地图列表中。

我正在使用groupBy

Map<Integer, List<Course>>  result = courses.stream()
        .collect(Collectors.groupingBy(c -> c.getTeacher().getTeacherId(), Collectors.toList()));

它正在按预期给出结果。

但我想在此limit ,只要找到5名教师停止处理并返回结果。

如何做呢??

没有直接支持这一点,因为停止和生活可能不完整的数据是相当不寻常的。

完全收集前五个组的直接解决方案是

Set<Integer> firstFive = courses.stream()
    .map(c -> c.getTeacher().getTeacherId())
    .distinct().limit(5)
    .collect(Collectors.toSet());
Map<Integer, List<Course>> result = courses.stream()
    .filter(c -> firstFive.contains(c.getTeacher().getTeacherId()))
    .collect(Collectors.groupingBy(c -> c.getTeacher().getTeacherId()));

这里,前五个教师ID的Course列表已经完成。


在遇到第5个教师ID后真正停止的解决方案,循环更简单:

Map<Integer, List<Course>> result = new HashMap<>();
for(Course c: courses) {
    result.computeIfAbsent(c.getTeacher().getTeacherId(), x -> new ArrayList<>()).add(c);
    if(result.size() == 5) break;
}

但收集Course列表没有多大意义,之后你不能相信这些列表。 请记住,即使源列表的最后一个元素也可能属于第一个遇到的教师ID,因此即使您只对一个教师的完整课程列表感兴趣,也需要处理整个列表。

不确定这是不是你要问的。

Map<Integer, List<Course>> map = new HashMap<>();

courses.stream().filter(course -> map.keySet().size() < 10)
    .forEach(entry -> {
       // The code below can be simplified
      int teacherId = entry.getTeacher().getTeacherId();
      if(map.get(teacherId) != null)
        map.get(teacherId).add(entry);
      else
        map.put(teacherId, Lists.newArrayList(entry));
    });

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM