java, map,如何实现当读入的key发生重复时,只保留重复key的第一行?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java, map,如何实现当读入的key发生重复时,只保留重复key的第一行?相关的知识,希望对你有一定的参考价值。
public static void main(String[] args)String[] keys = "aaaa", "bbbb", "cccc", "bbbb";
String[] values = "aaaaValue", "bbbbValue1", "ccccValue", "bbbbValue2";
Map<String, String> map = new HashMap<String, String>();
for (int i = 0; i < keys.length; i++)
if (!map.containsKey(keys[i]))
map.put(keys[i], values[i]);
for(String key : map.keySet())
System.out.println(key+"="+map.get(key));
bbbb=bbbbValue1
aaaa=aaaaValue
cccc=ccccValue 参考技术A 你设置判断语句不就OK了?
允许Key重复的Map - IdentityHashMap
在使用map的时候,大家肯定会想到key-value,key用于检索value的内容。在正常情况下,可以不允许重复;但是其实重复在java中分为2中情况,一是内存地址重复,另一个是不同的地址但内容相等,而IdentityHashMap用于后者,即内容相等。 更详细的解释如下:此类利用哈希表实现 Map 接口,比较键(和值)时使用引用相等性代替对象相等性。换句话说,在 IdentityHashMap 中,当且仅当 (k1==k2) 时,才认为两个键 k1 和 k2 相等(在正常 Map 实现(如 HashMap)中,当且仅当满足下列条件时才认为两个键 k1 和 k2 相等:(k1==null ? k2==null : e1.equals(e2)))。 此类不是 通用 Map 实现!此类实现 Map 接口时,它有意违反 Map 的常规协定,该协定在比较对象时强制使用 equals 方法。此类设计仅用于其中需要引用相等性语义的罕见情况。 例如: class Person{ private String name ; private int age ; public Person(String name,int age){ this.name = name ; this.age = age ; } public String toString(){ return "姓名:" + this.name + ",年龄:" + this.age ; } };
HashMap情况: public class IdentityHashMapDemo01{ public static void main(String args[]){ Map<Person,String> map = new HashMap<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 = map.entrySet() ; Iterator<Map.Entry<Person,String>> iter = allSet.iterator() ; while(iter.hasNext()){ Map.Entry<Person,String> me = iter.next() ; System.out.println(me.getKey() + " --> " + me.getValue()) ; } } };
结果:相同的key内容,value会被覆盖 姓名:李四,年龄:31 --> lisi 姓名:张三,年龄:30 --> zhangsan_2
IdentityHashMap情况 public class IdentityHashMapDemo02{ public static void main(String args[]){ Map<Person,String> 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 = map.entrySet() ; Iterator<Map.Entry<Person,String>> iter = allSet.iterator() ; while(iter.hasNext()){ Map.Entry<Person,String> me = iter.next() ; System.out.println(me.getKey() + " --> " + me.getValue()) ; } } };
结果:相同的key内容(由于是new出来的,内存地址不同但内容相同),但value不会被覆盖 姓名:张三,年龄:30 --> zhangsan_2 姓名:张三,年龄:30 --> zhangsan_1 姓名:李四,年龄:31 --> lisi
以上是关于java, map,如何实现当读入的key发生重复时,只保留重复key的第一行?的主要内容,如果未能解决你的问题,请参考以下文章
java中key值可以重复的map:IdentityHashMap