• IdentityHashMap类:增加相同Key(键)内容的结果


    正常Map操作中,key是不能重复的。

    先看使用HashMap()操作,增加相同Key内容的结果:

    先看代码:

    package 类集;
    import java.util.HashMap;
    import java.util.Iterator;
    import java.util.Map;
    import java.util.Set;
    class Person{
        private String name ;
        private int age ;
        public Person(String name,int age){
            this.name = name ;
            this.age = age ;
        }
        public boolean equals(Object obj){
            if(this==obj){
                return true ;
            }
            if(!(obj instanceof Person)){
                return false ;
            }
            Person p = (Person)obj ;
            if(this.name.equals(p.name)&&this.age==p.age){
                return true ;
            }else{
                return false ;
            }
        }
        public int hashCode(){
            return this.name.hashCode() * this.age ;
        }
        public String toString(){
            return "姓名:" + this.name + ",年龄:" + this.age ;
        }
    };
    public class test1{
        public static void main(String args[]){
            Map<Person,String> map = null ;    // 声明Map对象
            map = new HashMap<Person,String>() ;
            map.put(new Person("张三",30),"zhangsan_1") ;    // 加入内容
            map.put(new Person("张三",30),"zhangsan_2") ;    // 加入相同键key的内容
            map.put(new Person("李四",31),"lisi") ;    // 加入内容
            Set<Map.Entry<Person,String>> allSet = null ;    // 准备使用Set接收全部内容
            allSet = map.entrySet() ;
            Iterator<Map.Entry<Person,String>> iter = null ;
            iter = allSet.iterator() ;
            while(iter.hasNext()){
                Map.Entry<Person,String> me = iter.next() ;
                System.out.println(me.getKey() + " --> " + me.getValue()) ;
            }
        }
    };

    输出结果:

    姓名:张三,年龄:30 --> zhangsan_2
    姓名:李四,年龄:31 --> lisi

    可见,HashMap()操作的时候,key内容是不能重复的,当新增相同key的内容时候,新增内容会替换掉原来的key的内容

    要想key内容能够重复(指的是两个对象的地址不一样,key1!=key2)。则要使用IdentityHashMap类。

    替换掉HashMap后的结果:

    package 类集;
    import java.util.HashMap;
    import java.util.IdentityHashMap;
    import java.util.Iterator;
    import java.util.Map;
    import java.util.Set;
    class Person{
        private String name ;
        private int age ;
        public Person(String name,int age){
            this.name = name ;
            this.age = age ;
        }
        public boolean equals(Object obj){
            if(this==obj){
                return true ;
            }
            if(!(obj instanceof Person)){
                return false ;
            }
            Person p = (Person)obj ;
            if(this.name.equals(p.name)&&this.age==p.age){
                return true ;
            }else{
                return false ;
            }
        }
        public int hashCode(){
            return this.name.hashCode() * this.age ;
        }
        public String toString(){
            return "姓名:" + this.name + ",年龄:" + this.age ;
        }
    };
    public class test1{
        public static void main(String args[]){
            Map<Person,String> map = null ;    // 声明Map对象
            map = new IdentityHashMap<Person,String>() ;
            map.put(new Person("张三",30),"zhangsan_1") ;    // 加入内容
            map.put(new Person("张三",30),"zhangsan_2") ;    // 加入内容
            map.put(new Person("李四",31),"lisi") ;    // 加入内容
            Set<Map.Entry<Person,String>> allSet = null ;    // 准备使用Set接收全部内容
            allSet = map.entrySet() ;
            Iterator<Map.Entry<Person,String>> iter = null ;
            iter = allSet.iterator() ;
            while(iter.hasNext()){
                Map.Entry<Person,String> me = iter.next() ;
                System.out.println(me.getKey() + " --> " + me.getValue()) ;
            }
        }
    };

    输出结果:

    姓名:张三,年龄:30 --> zhangsan_1
    姓名:李四,年龄:31 --> lisi
    姓名:张三,年龄:30 --> zhangsan_2

    正常输出重复的结果!

  • 相关阅读:
    求100-999之间所有的水仙花数
    验证用户密码程序
    【bzoj2002】[Hnoi2010]Bounce 弹飞绵羊 分块/LCT
    【bzoj1070】[SCOI2007]修车 最小费用流
    【bzoj3669】[Noi2014]魔法森林 Kruskal+LCT
    【bzoj3668】[Noi2014]起床困难综合症 贪心
    【bzoj1391】[Ceoi2008]order 网络流最小割
    【bzoj4873】[Shoi2017]寿司餐厅 最大权闭合图
    【bzoj1180】[CROATIAN2009]OTOCI LCT
    【bzoj3282】Tree LCT
  • 原文地址:https://www.cnblogs.com/alsf/p/6231148.html
Copyright © 2020-2023  润新知