是否有一个非终端版本的groupingBy或其他一些简洁的方式来流的结果地图条目/值?
我发现自己想在groupingBy之后不断地浏览这些值,但是我所能想到的最好的方法并不是很好:
StreamEx.ofValues(
StreamEx.of(0, 1, 2, 4).groupingBy(i -> i % 2)
).mapToInt(ii -> IntStreamEx.of(ii).sum())
// RESULT: [6, 1]发布于 2016-02-09 11:25:42
在一个流管道中这样做可能需要想要的操作像一个完全的屏障:为了对值进行分组,我们需要处理所有这些值,以查看哪些值是偶数和奇数(并且能够对它们进行求和)。
因此,最好使用临时数据结构来保存偶数值和奇数值的计数,在这种情况下,这将是一个Map<Integer, Integer>或偶数Map<Boolean, Integer> (例如,关键是偶数值的true,奇值的false,使用Collectors.partitioningBy)。
请注意,这里不需要使用StreamEx库。您可以直接这样做-- Stream:
public static void main(String[] args) {
Map<Integer, Integer> map =
Stream.of(0, 1, 2, 4)
.collect(Collectors.groupingBy(
i -> i % 2,
Collectors.summingInt(i -> i)
));
Stream<Integer> stream = map.values().stream();
}发布于 2016-02-09 14:38:41
对于这个特定问题,summingInt可能是最好的解决方案。
我想我在我的例子中使用了ints来过度简化这个问题。我的实际问题是合并对象,而不是int值。我发现collectingAndThen非常有用。它的工作方式如下:
Function<List<Integer>, Integer> merge = ii -> ii.stream().mapToInt(i -> i).sum();
Stream.of(0, 1, 2, 4).collect(groupingBy(i -> i % 2, collectingAndThen(toList(), merge))).values();https://stackoverflow.com/questions/35290487
复制相似问题