繁体   English   中英

如何合并从执行程序Future返回的Multimaps列表与Java8

[英]How to merge List of Multimaps returned from executors Future with Java8

假设我有以下片段:(未来是可调用任务的结果)

List<Map<String, List<Offset>>> results = new ArrayList<>();

for (Future<Map<String, List<Offset>>> future : listFutures)   {
    Map<String, List<Offset>> mapResult = future.get();
    results.add(mapResult);
}

我想将所有"Map<String, List<Offset>>"聚合成所有Futures flatMap ,用例将是地图之间的重复键,在这种情况下我需要将值添加到List<Offset>

我期望在flatMap之后,得到"Map<String, List<Offset>>"

PS

我看到了一些例子,但他们在迭代期间没有说话。

       Stream.concat(map1.entrySet().stream(), map2.entrySet().stream())
                        .collect(Collectors.toMap(
                            entry -> entry.getKey(), 
                            entry -> entry.getValue()
                        )
                    );

有什么建议吗?

如果我把一切都搞定了......

listFutures.stream()
            .map(x -> {
                try {
                    return x.get();
                } catch (InterruptedException | ExecutionException e) {
                    throw new RuntimeException(e);
                }
            })
            .flatMap(x -> x.entrySet().stream())
            .collect(Collectors.toMap(
                    Entry::getKey,
                    Entry::getValue,
                    (left, right) -> {
                        left.addAll(right);
                        return left;
                    }));

并且可能是一种更简单的方法:

    for (Future<Map<String, List<Offset>>> f : listFutures) {
        Map<String, List<Offset>> inner = f.get();
        for (Entry<String, List<Offset>> e : inner.entrySet()) {
            results.merge(e.getKey(), e.getValue(), (left, right) -> {
                left.addAll(right);
                return left;
            });
        }
    }

暂无
暂无

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

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