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