文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2023-07-05 15:19

关注

这篇“基于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值问题怎么解决”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯