罪魁祸首就是HashMap的merge方法了,它的第一行就是这个:
代码语言:javascript复制if (value == null)
throw new NullPointerException();
为什么会调merge方法呢,toMap方法调的
代码语言:javascript复制public static <T, K, U, M extends Map<K, U>>
Collector<T, ?, M> toMap(Function<? super T, ? extends K> keyMapper,
Function<? super T, ? extends U> valueMapper,
BinaryOperator<U> mergeFunction,
Supplier<M> mapSupplier) {
BiConsumer<M, T> accumulator
= (map, element) -> map.merge(keyMapper.apply(element),
valueMapper.apply(element), mergeFunction);
return new CollectorImpl<>(mapSupplier, accumulator, mapMerger(mergeFunction), CH_ID);
}
那么怎么解决呢? 既然时merge方法造成的,那就不调merge方法。 我们用自己定义的accumulator,用Stream的另一个collect方法
代码语言:javascript复制<R> R collect(Supplier<R> supplier,
BiConsumer<R, ? super T> accumulator,
BiConsumer<R, R> combiner);
这个方法上面的注释写了一段这个, 前两个参数干什么用的就很清楚了,第三个参数时并行计算用来组合结果的,所以用HashMap的putAll就好了
代码语言:javascript复制R result = supplier.get();
for (T element : this stream)
accumulator.accept(result, element);
return result;
所以解决办法的代码大概就是这样的
代码语言:javascript复制params.stream().collect(LinkedHashMap::new, (m, v) -> m.put(v.getParam(), v.getParamValue()), LinkedHashMap::putAll);
据说这个问题java9就修复了,所以也可以尝试升级jdk
作者:l-qiang 链接:https://juejin.cn/post/6844903934855741447 来源:掘金 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。