zoukankan      html  css  js  c++  java
  • 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

    正常输出重复的结果!

  • 相关阅读:
    前端技术-PS切图
    Html5资料整理
    Html5知识体系
    Html知识体系
    C语言知识结构
    ASP.NET知识结构
    src和href的区别
    Ajax的简单使用
    学习理论
    求模运算法则
  • 原文地址:https://www.cnblogs.com/alsf/p/6231148.html
Copyright © 2011-2022 走看看