java中常见的三个集合接口:list、set、map,已经知道list中是允许有重复元素的,而set中是不允许有重复元素的,那么map中允许有重复元素吗?
查阅资料,发现是不可以的,因为map是无序的,它的查询需要通过key的值来查找,如果你定义两个同样的key,那么一个key就对应了多个值,这样就违背了java对map的定义,键和值是一一对应的。所以key不可以重复。
写个代码测试一下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
package com.test.collection; import java.util.hashmap; import java.util.map; //map中key值不可重复的测试 public class testequals { public static void main(string[] args) { string s1= new string( "abc" ); string s2= new string( "abc" ); map map= new hashmap(); map.put(s1, "abc123" ); map.put(s2, "abc456" ); //第二个会覆盖第一个元素 //注意:map中key值不可重复,直接根据比较的是equals,只有equals相同则覆盖 system.out.println(map.size()); system.out.println(map.get(s1)); } } |
输出结果:
1
abc456
如果key重复,应该选取这个key对应的哪个值放入容器呢?做了一下测试:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
public class test { public static map putsome(map<string,string> map){ map.put( "gender" , "male" ); map.put( "name" , "athor" ); map.put( "name" , "cindy" ); map.put( "name" , "billy" ); map.put( "from" , "china" ); return map; } public static void main(string[] args) { system.out.println(putsome( new hashmap<string,string>())); system.out.println(putsome( new treemap<string,string>())); system.out.println(putsome( new linkedhashmap<string,string>())); } } |
输出结果:
{name=billy, gender=male, from=china}
{from=china, gender=male, name=billy}
{gender=male, name=billy, from=china}
可见不论是map的哪个子类,键name对应的值都是billy,即最后一个name的键值对,它覆盖了之前的name键值对。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对服务器之家的支持。如果你想了解更多相关内容请查看下面相关链接
原文链接:https://blog.csdn.net/zqxhit1234/article/details/80773322