【Java】Exception in thread main java.lang.IllegalStateException: Duplicate key

本文主要是介绍【Java】Exception in thread main java.lang.IllegalStateException: Duplicate key,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

java8 stream 的toMap方法,如果key有重复的就会跑出上面的异常,比如:

        List<Integer> list = new ArrayList<>();list.add(1);list.add(2);list.add(1);System.out.println(list.stream().collect(Collectors.toMap(e->e, e->"hello")));

Exception in thread "main" java.lang.IllegalStateException: Duplicate key 1
    at java.util.stream.Collectors.lambda$throwingMerger$0(Collectors.java:133)
    at java.util.HashMap.merge(HashMap.java:1254)
    at java.util.stream.Collectors.lambda$toMap$58(Collectors.java:1320)
    at java.util.stream.ReduceOps$3ReducingSink.accept(ReduceOps.java:169)
    at java.util.ArrayList$ArrayListSpliterator.forEachRemaining(ArrayList.java:1382)
    at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:481)
    at java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:471)
    at java.util.stream.ReduceOps$ReduceOp.evaluateSequential(ReduceOps.java:708)
    at java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234)
    at java.util.stream.ReferencePipeline.collect(ReferencePipeline.java:499)
    at com.liyao.AAA.main(AAA.java:32)

解决办法是:使用重载方法,多传入一个merge function来处理冲突

        List<Integer> list = new ArrayList<>();list.add(1);list.add(2);list.add(1);
//        System.out.println(list.stream().collect(Collectors.toMap(e->e, e->"hello")));System.out.println(list.stream().collect(Collectors.toMap(e->e, e->"1", (k,v)->k + "world")));
 /*** Returns a {@code Collector} that accumulates elements into a* {@code Map} whose keys and values are the result of applying the provided* mapping functions to the input elements.** <p>If the mapped* keys contains duplicates (according to {@link Object#equals(Object)}),* the value mapping function is applied to each equal element, and the* results are merged using the provided merging function.** @apiNote* There are multiple ways to deal with collisions between multiple elements* mapping to the same key.  The other forms of {@code toMap} simply use* a merge function that throws unconditionally, but you can easily write* more flexible merge policies.  For example, if you have a stream* of {@code Person}, and you want to produce a "phone book" mapping name to* address, but it is possible that two persons have the same name, you can* do as follows to gracefully deals with these collisions, and produce a* {@code Map} mapping names to a concatenated list of addresses:* <pre>{@code*     Map<String, String> phoneBook*         people.stream().collect(toMap(Person::getName,*                                       Person::getAddress,*                                       (s, a) -> s + ", " + a));* }</pre>** @implNote* The returned {@code Collector} is not concurrent.  For parallel stream* pipelines, the {@code combiner} function operates by merging the keys* from one map into another, which can be an expensive operation.  If it is* not required that results are merged into the {@code Map} in encounter* order, using {@link #toConcurrentMap(Function, Function, BinaryOperator)}* may offer better parallel performance.** @param <T> the type of the input elements* @param <K> the output type of the key mapping function* @param <U> the output type of the value mapping function* @param keyMapper a mapping function to produce keys* @param valueMapper a mapping function to produce values* @param mergeFunction a merge function, used to resolve collisions between*                      values associated with the same key, as supplied*                      to {@link Map#merge(Object, Object, BiFunction)}* @return a {@code Collector} which collects elements into a {@code Map}* whose keys are the result of applying a key mapping function to the input* elements, and whose values are the result of applying a value mapping* function to all input elements equal to the key and combining them* using the merge function** @see #toMap(Function, Function)* @see #toMap(Function, Function, BinaryOperator, Supplier)* @see #toConcurrentMap(Function, Function, BinaryOperator)*/public static <T, K, U>Collector<T, ?, Map<K,U>> toMap(Function<? super T, ? extends K> keyMapper,Function<? super T, ? extends U> valueMapper,BinaryOperator<U> mergeFunction) {return toMap(keyMapper, valueMapper, mergeFunction, HashMap::new);}

 

这篇关于【Java】Exception in thread main java.lang.IllegalStateException: Duplicate key的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/999553

相关文章

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

java中新生代和老生代的关系说明

《java中新生代和老生代的关系说明》:本文主要介绍java中新生代和老生代的关系说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、内存区域划分新生代老年代二、对象生命周期与晋升流程三、新生代与老年代的协作机制1. 跨代引用处理2. 动态年龄判定3. 空间分

Java设计模式---迭代器模式(Iterator)解读

《Java设计模式---迭代器模式(Iterator)解读》:本文主要介绍Java设计模式---迭代器模式(Iterator),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录1、迭代器(Iterator)1.1、结构1.2、常用方法1.3、本质1、解耦集合与遍历逻辑2、统一

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空

深度解析Java DTO(最新推荐)

《深度解析JavaDTO(最新推荐)》DTO(DataTransferObject)是一种用于在不同层(如Controller层、Service层)之间传输数据的对象设计模式,其核心目的是封装数据,... 目录一、什么是DTO?DTO的核心特点:二、为什么需要DTO?(对比Entity)三、实际应用场景解析

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1