「這裡是雲端源想IT,幫你輕鬆學IT」
嗨~ 今天的你過得還好嗎?
要相信
所有的不美好都是為了迎接美好,
所有的困難都會為努力讓道。
- 2023.12.04 -
Map是一種雙列集合,一個元素包含兩個值,一個是Key,一個是Value。Map集合中的元素,key和value的數據類型可以相同,也可以不同。一個映射不能包含重複的鍵;每個鍵最多只能有一個值。
今天我們繼續探索java集合的世界,這次我們要聊的主題是——雙列集合Map。
首先,讓我們來理解一下什麼是雙列集合。在Java中,集合是一種用於存儲對象的容器,而雙列集合則是一種可以同時通過兩個鍵(Key)來訪問元素的集合。聽起來有些複雜?別擔心,接下來我會用最簡單的語言,帶你走進Map的世界。
一、概述
現實生活中,我們常會看到這樣的一種集合:IP地址與主機名,身份證號與個人,學號與學生等,這種一一對應的關係,就叫做映射。Java提供了專門的集合類用來存放這種對象關係的對象,即java.util.Map接口。 Map接口下的集合與Collection 接口下的集合,他們的存儲形式有所不同,如下圖:
Collection 集合,元素是獨立的,存儲的元素是一個一個的存儲。Map中的集合,元素是成對出現。每個元素由鍵與值兩部分組成,通過鍵可以找到所對應的值。所以我們前面所說 Collection是單列集合,而Map為雙列集合。
需要注意:Map中的鍵不能重複,值可以重複,並且每個鍵只能對應一個值。
二、Map 常用子類
Map接口也有很多子類,這裡我們主要講解常用的HashMap集合和LinkedHashMap集合。
HashMap<K,V>
存儲數據採用哈希表結構,元素的存取順序不能保證一致。
由於要保證鍵的唯一,不重複,需要重寫鍵的hashCode()方法,equals()方法。我們之前所學的HashSet 底層,實際上也是new了一個HashMap,但是只是使用了 HashMap中的 K,所以HashSet是不允許重複值的。
LinkedHashMap<K,V>
HashMap下有個子類LinkedHashMap,存儲數據採用的哈希表結構+鏈表結構。
通過鏈表結構可以保證元素的存取順序一致;通過哈希表結構可以保證的鍵的唯一、不重複,需要重寫鍵的hashCode()方法、equals()方法。
Set與Map之間的關係非常密切,從Java源碼來看,Java是先實現了Map,然後通過包裝一個所有value都為null的Map,就實現了Set集合。
你還在苦惱找不到真正免費的編程學習平台嗎?可以試試雲端源想!課程視頻、在線書籍、在線編程、實驗場景模擬、一對一諮詢……你想要的全部學習資源這裡都有,重點是統統免費!點這裡即可進入:
而我們在遍歷Map集合時,就可以從每一個鍵值對對象中獲取對應的鍵,然後找到對應的值。
4.1鍵找值方式
在Map集合中,為我們提供了一個方法
- keySet() 獲取Map中所有的鍵,由於鍵是唯一的,所以返回一個Set集合存儲所有的鍵`。
那我們就可以遍歷這個Set集合,通過 Entry的方法
- public V getValue():獲取Entry對象中的Value值。
4.2 鍵值對方式
在Map集合中也提供了獲取所有Entry對象的方法:
public Set<Map.Entry<K,V>> entrySet(): 獲取到Map集合中所有的鍵值對對象的集合(Set集合)。
那我們就可以通過這個方法,獲取Map集合中,所有的鍵值對(Entry)對象的Set集合,然後遍歷包含Entry對象的Set集合,得到每一個Entry對象。通過鍵值對(Entry)對象,獲取Entry對象中的鍵與值。 方法提示:getkey() getValue()。
public class Demo3Map { public static void main(String[ ] args) { //方法一:keySet遍歷key+value: //創建集合對象 Map<String, Student> studentMap = new HashMap<>(); //將對應的對象放到map中 studentMap.put("N001", new Student("叮噹", 7)); studentMap.put("N002", new Student("糖糖", 7)); studentMap.put("N003", new Student("熙熙", 7)); //獲取 map集合中的所有key Set<String> strings = studentMap.keySet(); //遍歷 key的集合,通過get()獲取沒一個value for (String key : strings) { Student student = studentMap.get(key); System.out.println("studentmap == key="+key+" value="+ student); } //方法二:entrySet遍歷key+value: Set<Map.Entry<String, Student>> entries = studentMap.entrySet(); for (Map.Entry<String, Student> entry : entries) { String key = entry.getKey(); Student value = entry.getValue(); System.out.println("studentmap 方式2 == key="+key+" value="+ value); } } }
Map在實際應用中非常廣泛,例如在數據庫中存儲和查詢數據、在緩存中存儲和獲取數據、在處理用戶輸入和輸出時進行轉換等。通過使用Map,我們可以更高效地處理複雜的數據結構和業務邏輯。
總的來說,Map是Java集合框架中的一個重要組成部分,它的強大功能和靈活應用為我們的編程工作帶來了極大的便利。希望通過今天的學習,你能對Map有一個更深入的理解,並能在實際編程中靈活運用。
我們下期再見!
END
文案編輯|雲端學長
文案配圖|雲端學長
內容由:雲端源想分享