zoukankan      html  css  js  c++  java
  • java HashMap插入重复Key值问题

    今天在用到了HashMap来遍历所有非重复的Key时遇到了一个问题,在写入数据库的时候报错--主键不能重复插入。查看了好久java文档才得以解决。

    自定义一个类型

    class MyType {
        private String arga;
        private String argb;
     
        public MyType(String arga, String argb) {
            this.arga = arga;
            this.argb = argb;
        }
    }
    如果代码中用到类似
    HashMap<MyType, String> hm = new HashMap<MyType, String>();
    那么定义两个变量 
    MyType mta = new MyType("aaa", "bbb");
    MyType mtb = new MyTypr("aaa", "bbb");
    hm.put(mta, "xxx");
    hm.put(mtb, "xxx");

    猜下HashMap中有几个元素?
     
    答案是有两个,原因是mta和mtb放在了不同的内存地址里面,mta和mtb传进去的是引用,那么怎么样实现HashMap没有值相同的Key呢?
    方法很简单:只需要重写两个函数 public boolean equals(Object obj); 和 public int hashCode()
    如下:
    class MyType {
        private String arga;
        private String argb;
        public MyType(String arga, String argb) {
            this.arga = arga;
            this.argb = argb;
        }
     
        public int hashCode(){                 
         return this.arga.hashCode() * this.argb.hashCode() ; 
        } 
       
        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 ;                
           }       
        }
    }
    然后在进行

    MyType mta = new MyType("aaa", "bbb");
    MyType mtb = new MyTypr("aaa", "bbb");
    hm.put(mta, "xxx");
    hm.put(mtb, "xxx");

    你会发现,HashMap里只有一个Key了
     
    至于HashCode要怎么实现,我认为可以任意实现,取得不好只是会影响HashMap的效率,另外想要插入重复的Key可以使用IdentityHashMap,详见java document


    原文链接地址:点击这里

     

     


  • 相关阅读:
    MySQL (下篇)
    【JUC剖析】专栏总集篇
    CF1391D(思维)
    CF1393E2(字符串)
    洛谷P5405 [CTS2019]氪金手游(期望,容斥)
    P5293 [HNOI2019]白兔之舞(单位根反演)
    洛谷P5400 [CTS2019]随机立方体(计数)
    洛谷P5401 [CTS2019]珍珠(生成函数)
    支配树学习笔记
    UOJ455 雪灾与外卖(模拟费用流)
  • 原文地址:https://www.cnblogs.com/JackieZhu/p/4190470.html
Copyright © 2011-2022 走看看