Spliterator在for循环时导致重复键异常

时间:2017-05-26 17:56:15

标签: java cassandra java-8 java-stream

我正在使用Java 8流。

当我使用spliterator添加到我的地图时,我得到重复的键异常,但使用标准for循环不会抛出异常。

// This works
Map<Integer, String> myMap = new HashMap<>();
for (Row row : result.result()) {
    myMap.put(row.get(0, Integer.class), null);
}

// This throws exception
myMap = StreamSupport.stream(result.result().spliterator(), true)
    .collect(Collectors.toMap(row -> row.get(0, Integer.class), row -> ""));

如果它有任何区别,结果是Cassandra结果集,而行是Cassandra行。

1 个答案:

答案 0 :(得分:4)

当您使用标准for循环时,如果您放置Map中已存在的密钥,旧值将替换为新值。

另一方面,如果多个值映射到同一个键,则2个参数toMap collector会抛出异常。

为避免这种情况,您需要提供合并功能以处理此类冲突。

例如:

myMap = 
    StreamSupport.stream(result.result().spliterator(), true)
                 .collect(Collectors.toMap(row -> row.get(0, Integer.class), 
                                           row -> "",
                                           (v1,v2) -> v2));

这将采用其中一个值,并在发生碰撞时忽略另一个值。您可以选择其他合并功能,例如附加两个值:

(v1,v2) -> v1 + ", " + v2

正如Eugene评论的那样,结果会在遇到顺序中合并到Map