(Java集合框架)Map集合
Map集合
概述
現實生活中,常會看到這樣的一種集合:IP地址與主機名,身份證號與個人,系統用戶名與系統用戶對象等,這種一一對應的關系,就叫做映射。Java提供了專門的集合類用來存放這種對象關系的對象,即java.util.Map接口。
通過查看Map接口描述,發現Map接口下的集合與Collection接口下的集合,它們存儲數據的形式不同
- Collection中的集合,元素是孤立存在的(理解為單身),向集合中存儲元素采用一個個元素的方式存儲。
- Map中的集合,元素是成對存在的(理解為夫妻)。每個元素由鍵與值兩部分組成,通過鍵可以找對所對應的值。
- Collection中的集合稱為單列集合,Map中的集合稱為雙列集合。
- 需要注意的是,Map中的集合不能包含重復的鍵,值可以重復;每個鍵只能對應一個值。
Map常用子類
- HashMap<K,V>:存儲數據采用的哈希表結構,元素的存取順序不能保證一致。由于要保證鍵的唯一、不重復,需要重寫鍵的hashCode()方法、equals()方法。
- LinkedHashMap<K,V>:HashMap下有個子類LinkedHashMap,存儲數據采用的哈希表結構+鏈表結構。通過鏈表結構可以保證元素的存取順序一致;通過哈希表結構可以保證的鍵的唯一、不重復,需要重寫鍵的hashCode()方法、equals()方法。
tips:Map接口中的集合都有兩個泛型變量<K,V>,在使用時,要為兩個泛型變量賦予數據類型。兩個泛型變量<K,V>的數據類型可以相同,也可以不同。
Map接口中的常用方法
Map接口中定義了很多方法,常用的如下:
- public V put(K key, V value): 把指定的鍵與指定的值添加到Map集合中。
- public V remove(Object key): 把指定的鍵 所對應的鍵值對元素 在Map集合中刪除,返回被刪除元素的值。
- public V get(Object key) 根據指定的鍵,在Map集合中獲取對應的值。
- boolean containsKey(Object key) 判斷集合中是否包含指定的鍵。
- public Set<K> keySet(): 獲取Map集合中所有的鍵,存儲到Set集合中。
- public Set<Map.Entry<K,V>> entrySet(): 獲取到Map集合中所有的鍵值對對象的集合(Set集合)。
Map接口的方法演示
import java.util.HashMap; import java.util.Map; import java.util.Set;public class Demo01Map {/** `public V put(K key, V value)`: 把指定的鍵與指定的值添加到Map集合中。* `public V remove(Object key)`: 把指定的鍵 所對應的鍵值對元素 在Map集合中刪除,返回被刪除元素的值。* `public V get(Object key)` 根據指定的鍵,在Map集合中獲取對應的值。* `boolean containsKey(Object key) ` 判斷集合中是否包含指定的鍵。*/public static void main(String[] args) {//key不可以重復,value可以重復//創建對象,多態Map<String,String> map = new HashMap<>();//向map中添加元素map.put("伊澤瑞爾","射手");map.put("劫","刺客");map.put("厄斐琉斯","射手");map.put("奧恩","坦克");System.out.println("輸出集合:"+map);//判斷伊澤瑞爾是什么System.out.println("伊澤瑞爾是:"+map.get("伊澤瑞爾"));//判斷集合中是否存在伊澤瑞爾System.out.println("判斷集合中是否存在伊澤瑞爾:"+map.containsKey("伊澤瑞爾"));//刪除伊澤瑞爾map.remove("伊澤瑞爾");System.out.println("刪除伊澤瑞爾后的集合:"+map);} }tips:
使用put方法時,若指定的鍵(key)在集合中沒有,則沒有這個鍵對應的值,返回null,并把指定的鍵值添加到集合中;
若指定的鍵(key)在集合中存在,則返回值為集合中鍵對應的值(該值為替換前的值),并把指定鍵所對應的值,替換成指定的新值。
Map集合遍歷鍵找值方式
鍵找值方式:即通過元素中的鍵,獲取鍵所對應的值
分析步驟:
代碼演示:
import java.util.HashMap; import java.util.Map; import java.util.Set;public class Demo02Map {public static void main(String[] args) {//創建對象,多態Map<String,String> map = new HashMap<>();//向map中添加元素map.put("伊澤瑞爾","射手");map.put("劫","刺客");map.put("厄斐琉斯","射手");map.put("奧恩","坦克");//`public Set<K> keySet()`: 獲取Map集合中所有的鍵,存儲到Set集合中。Set<String> set = map.keySet();//增強for遍歷map集合for (String s : set) {String v = map.get(s);System.out.println(s+" 是 "+v);}} }Entry鍵值對對象
我們已經知道,Map中存放的是兩種對象,一種稱為key(鍵),一種稱為value(值),它們在在Map中是一一對應關系,這一對對象又稱做Map中的一個Entry(項)。Entry將鍵值對的對應關系封裝成了對象。即鍵值對對象,這樣我們在遍歷Map集合時,就可以從每一個鍵值對(Entry)對象中獲取對應的鍵與對應的值。
既然Entry表示了一對鍵和值,那么也同樣提供了獲取對應鍵和對應值得方法:
- public K getKey():獲取Entry對象中的鍵。
- public V getValue():獲取Entry對象中的值。
在Map集合中也提供了獲取所有Entry對象的方法:
- public Set<Map.Entry<K,V>> entrySet(): 獲取到Map集合中所有的鍵值對對象的集合(Set集合)。
Map集合遍歷鍵值對方式
鍵值對方式:即通過集合中每個鍵值對(Entry)對象,獲取鍵值對(Entry)對象中的鍵與值。
操作步驟與圖解:
獲取Map集合中,所有的鍵值對(Entry)對象,以Set集合形式返回。方法提示:entrySet()。
遍歷包含鍵值對(Entry)對象的Set集合,得到每一個鍵值對(Entry)對象。
通過鍵值對(Entry)對象,獲取Entry對象中的鍵與值。 方法提示:getkey() getValue()
tips:Map集合不能直接使用迭代器或者foreach進行遍歷。但是轉成Set之后就可以使用了。
HashMap存儲自定義類型鍵值
練習:每位英雄(姓名,職業)都有自己的所屬勢力。那么,既然有對應關系,則將英雄對象和所屬勢力存儲到map集合中。英雄作為鍵, 所屬勢力作為值。
注意
- 英雄姓名相同并且職業相同視為同一名英雄。
編寫英雄類:
import java.util.Objects;public class Hero {private String name;private String heroJob;public Hero() {}public Hero(String name, String heroJob) {this.name = name;this.heroJob = heroJob;}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getHeroJob() {return heroJob;}public void setHeroJob(String heroJob) {this.heroJob = heroJob;}@Overridepublic boolean equals(Object o) {if (this == o) return true;if (o == null || getClass() != o.getClass()) return false;Hero hero = (Hero) o;return Objects.equals(name, hero.name) &&Objects.equals(heroJob, hero.heroJob);}@Overridepublic int hashCode() {return Objects.hash(name, heroJob);} }編寫測試類:
import java.util.HashMap; import java.util.Map; import java.util.Set;public class Demo04HashMap {public static void main(String[] args) {//創建HashMap集合對象HashMap<Hero,String> map = new HashMap<>();map.put(new Hero("伊澤瑞爾","射手"),"皮爾特沃夫");map.put(new Hero("蓋倫","坦克"),"德瑪西亞");map.put(new Hero("艾希","射手"),"德瑪西亞");map.put(new Hero("艾希","射手"),"弗雷爾卓德");//注:因為重寫了Hero類equals和hashCode方法所以map可以判斷Hero對象的值是否重復//用EntrySet遍歷集合Set<Map.Entry<Hero, String>> entries = map.entrySet();for (Map.Entry<Hero, String> entry : entries) {Hero hero = entry.getKey();String heroCountry = entry.getValue();System.out.println(hero.getName()+" 是 "+hero.getHeroJob()+" 屬于 "+heroCountry);}} }- 當給HashMap中存放自定義對象時,如果自定義對象作為key存在,這時要保證對象唯一,必須復寫對象的hashCode和equals方法(如果忘記,請回顧HashSet存放自定義對象)。
- 如果要保證map中存放的key和取出的順序一致,可以使用java.util.LinkedHashMap集合來存放。
LinkedHashMap
我們知道HashMap保證成對元素唯一,并且查詢速度很快,可是成對元素存放進去是沒有順序的,那么我們要保證有序,還要速度快怎么辦呢?
在HashMap下面有一個子類LinkedHashMap,它是鏈表和哈希表組合的一個數據存儲結構。用法和HashMap相同。
《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀總結
以上是生活随笔為你收集整理的(Java集合框架)Map集合的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: (Java集合框架)List接口
- 下一篇: (仿头条APP项目)7.首页标签页完善和