广告
返回顶部
首页 > 资讯 > 精选 >基于java HashMap插入重复Key值问题怎么解决
  • 508
分享到

基于java HashMap插入重复Key值问题怎么解决

2023-07-05 15:07:01 508人浏览 八月长安
摘要

这篇“基于java HashMap插入重复Key值问题怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“基于j

这篇“基于java HashMap插入重复Key值问题怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“基于java HashMap插入重复Key值问题怎么解决”文章吧。

java HashMap插入重复Key值

要在HashMap中插入重复的值,首先需要弄清楚HashMap里面是怎么存放元素的。

put方法

Map里面存放的每一个元素都是key-value这样的键值对,而且都是通过put方法进行添加的,而且相同的key在Map中只会有一个与之关联的value存在。put方法在Map中的定义如下。

V put(K key, V value);

put()方法实现:

首先hash(key)得到key的hashcode(),hashmap根据获得的hashcode找到要插入的位置所在的链,在这个链里面放的都是hashcode相同的Entry键值对,在找到这个链之后,会通过equals()方法判断是否已经存在要插入的键值对,而这个equals比较的其实就是key。

它用来存放key-value这样的一个键值对,返回值是key在Map中存放的旧value,如果之前不存在则返回null。HashMap的put方法是这样实现的。

// 在此映射中关联指定值与指定键。如果该映射以前包含了一个该键的映射关系,则旧值被替换public V put(K key, V value) {    // 当key为null,调用putForNullKey方法,保存null与table第一个位置中,这是HashMap允许为null的原因     if (key == null)        return putForNullKey(value);    // 使用hash函数预处理hashCode,计算key的hash值      int hash = hash(key.hashCode());//-------(1)    // 计算key hash 值在 table 数组中的位置     int i = indexFor(hash, table.length);//------(2)    // 从i出开始迭代 e,找到 key 保存的位置    for (Entry<K, V> e = table[i]; e != null; e = e.next) {        Object k;        // 判断该条链上是否有hash值相同的(key相同)         // 若存在相同,则直接覆盖value,返回旧value         if (e.hash == hash && ((k = e.key) == key || key.equals(k))) {            // 旧值 = 新值              V oldValue = e.value;            // 将要存储的value存进去            e.value = value;            e.recordAccess(this);            // 返回旧的value            return oldValue;        }    }    // 修改次数增加1     modCount++;    // 将key、value添加至i位置处     addEntry(hash, key, value, i);    return null;}

从上我们可以看到在添加对应的key-value这样的组合时,如果原本已经存在对应的key,则直接改变对应的value,并返回旧的value,而在判断key是否存在的时候是先比较key的hashCode,再比较相等或equals的。

直接从上面代码来看是比较的对应Map.Entry的hashCode和key的hashCode,而实际上Map.Entry的hashCode其实就是其存放key的hashCode。

而如果对应的key原本不存在的话将调用addEntry将对应的key-value添加到Map中。

addEntry传递的参数hash就是对应key的hashCode。

实现引用对象作为keys的唯一性

通过对put()方法的研究,我们可以发现,判断key是否存在的时候是先比较key的hashCode,再比较相等或equals的,所以重写hashCode()和equals()方法即可实现覆盖keys的引用(指向具有相同实例变量的对象)。

class MyType {    private String arga;    private String argb;    public MyType(String arga, String argb) {        this.arga = arga;        this.argb = argb;    }    @Override    public int hashCode(){                          return this.arga.hashCode() * this.argb.hashCode() ;     }         @Override    public boolean equals(Object obj) {           if (this == obj) {                           return true;                          }                 if (!(obj instanceof MyType)) {              return false;                       }            MyType p = (MyType) obj;          if (this.arga.equals(p.arga) && this.argb.equals(p.argb)) {                          return true ;                          } else {                       return false ;                        }           }}

重写这两个方法之后就可以覆盖重复的引用对象,如果需要对value进行叠加,调用put()方法之前用containsKey()方法判断是否有重复的键值,如果有,则用get()方法获取原有的value,再加上新加入的value即可。

HashMap解决key值相同问题

某些场景需要一个key值下面对应多个值,但是map的一个key值只对应一个value值,由于hashmap相同的key值,第二个put进去会覆盖第一个的值,所以为了解决这一问题:所以用list存

如下:

List<Map<String, List<RecommendationListBO>>> hashList = new ArrayList<>();Iterator<Map.Entry<String, List<RecommendationListBO>>> iterator = recommendationHashMap.entrySet().iterator();Map.Entry<String, List<RecommendationListBO>> entry;while (iterator.hasNext()) {    entry = iterator.next();    // 往newMap中放入新的Entry    HashMap<String, List<RecommendationListBO>> newMap = new LinkedHashMap<>();    newMap.put(entry.geTKEy().split(",")[0], entry.getValue());    hashList.add(newMap);}

每次new一个新的map,add到map的list里面。思路大概是这样的。

以上就是关于“基于java HashMap插入重复Key值问题怎么解决”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网精选频道。

--结束END--

本文标题: 基于java HashMap插入重复Key值问题怎么解决

本文链接: https://www.lsjlt.com/news/352707.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 基于java HashMap插入重复Key值问题怎么解决
    这篇“基于java HashMap插入重复Key值问题怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“基于j...
    99+
    2023-07-05
  • 基于javaHashMap插入重复Key值问题
    目录java HashMap插入重复Key值put方法实现引用对象作为keys的唯一性HashMap解决key值相同问题总结java HashMap插入重复Key值 要在HashMa...
    99+
    2023-03-22
    java HashMap Key HashMap插入重复Key值 java HashMap重复Key值
  • 怎么解决java并发请求下数据插入重复问题
    本篇内容介绍了“怎么解决java并发请求下数据插入重复问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!前言前段时间发现数据库里经常会存在两...
    99+
    2023-06-25
  • java怎么解决重复提交问题
    在Java中,可以通过以下几种方式来解决重复提交问题:1. 后端防重复提交:在后端服务器中通过生成并保存一个唯一的Token,将To...
    99+
    2023-08-19
    java
  • java并发请求下数据插入重复问题的解决方法
    目录前言分布式锁工具类在过滤器实现请求拦截总结前言 前段时间发现数据库里经常会存在两条相同的用户数据,导致数据查询异常。查了原因,发现前端微信小程序在授权登录时,有时会出现同时发送了...
    99+
    2022-11-12
  • mysql8.0出现自增列值重复利用问题怎么样解决
    下文主要给大家带来mysql8.0出现自增列值重复利用问题怎么样解决,希望这些内容能够带给大家实际用处,这也是我编辑mysql8.0出现自增列值重复利用问题怎么样解决这篇文章的主要目的。好了,废话不多说,大...
    99+
    2022-10-18
  • 基于element UI input组件自行封装数字区间输入框组件的问题怎么解决
    今天小编给大家分享一下基于element UI input组件自行封装数字区间输入框组件的问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这...
    99+
    2023-06-30
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作