异常来源
java.lang.IllegalStateException: Duplicate key xxxx
at java.base/java.util.stream.Collectors.duplicateKeyException(Collectors.java:135)
at java.base/java.util.stream.Collectors.lambda$uniqKeysMapAccumulator$1(Collectors.java:182)
at java.base/java.util.stream.ReduceOps$3ReducingSink.accept(ReduceOps.java:169)
at java.base/java.util.stream.ReferencePipeline$2$1.accept(ReferencePipeline.java:179)
at java.base/java.util.ArrayList$ArrayListSpliterator.forEachRemaining(ArrayList.java:1625)
at java.base/java.util.stream.ReferencePipeline$Head.forEach(ReferencePipeline.java:762)
at java.base/java.util.stream.ReferencePipeline$7$1.accept(ReferencePipeline.java:27
在使用Stream流输出Java Map集合时,有时候会遇到如上的异常。那原因基本是属于:
转换后的Map中存在重复的Key.
明细原因就千姿百态(千奇百怪)了,可能是从数据库查询出来或者用户输入(导入)的数据存在重复的。
这时候很多人其实会想先手动去重,然后在使用Stream导出。
其实不用这么麻烦,Stream早就给我们准备好了~
解决方案
Collectors.toMap方法除了有两个参数之外还有个三个参数的,那这第三个参数的作用就是:
用来处理生成数据后可能存在重复Key的问题。
使用示例如下:
🌰1:
Map<Long, String> map = orderList.stream()
.collect(Collectors.toMap(Order::getId, Order::getPrice, (v1, v2) -> v1));
🌰2:
Map<Long, String> map = orderList.stream()
.collect(Collectors.toMap(Order::getId, Order::getPrice, (v1, v2) -> v2));
你看出两个🌰有什么区别了吗?