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