Map介面---Day20

来源:https://www.cnblogs.com/hpcz190911/archive/2019/11/12/11839425.html
-Advertisement-
Play Games

Map介面概述: 現實生活中,我們常會看到這樣的一種集合:IP地址與主機名,身份證號與個人,系統用戶名與系統用戶對象等, 這種一一對應的關係,就叫做映射。Java提供了專門的集合類用來存放這種對象關係的對象,即 java.util.Map 介面 Map介面與Collection介面的區別: Coll ...


Map介面概述:

  現實生活中,我們常會看到這樣的一種集合:IP地址與主機名,身份證號與個人,系統用戶名與系統用戶對象等, 這種一一對應的關係,就叫做映射。Java提供了專門的集合類用來存放這種對象關係的對象,即 java.util.Map 介面

Map介面與Collection介面的區別:

  

  Collection 中的集合,元素是孤立存在的(可以理解為單身),向集合中存儲元素採用一個個元素的方式存儲。

  Map 中的集合,元素是成對存在的(可以理解為夫妻)。每個元素由鍵與值兩部分組成,通過鍵可以找對所對應的 值。

  Collection 中的集合稱為單列集合, Map 中的集合稱為雙列集合。

  需要註意的是,Map 中的集合不能包含重覆的鍵,值可以重覆;每個鍵只能對應一個值。

Map常用子類:

  HashMap:存儲數據採用的哈希表結構,元素的存取順序不能保證一致。由於要保證鍵的唯一、不重覆,需 要重寫鍵的hashCode()方法、equals()方法。

  LinkedHashMap:HashMap下有個子類LinkedHashMap,存儲數據採用的哈希表結構+鏈表結構。通過鏈 表結構可以保證元素的存取順序一致;通過哈希表結構可以保證的鍵的唯一、不重覆,需要重寫鍵的 hashCode()方法、equals()方法。

Map介面中的常用方法

  Map介面中定義了很多方法,常用的如下:

    public V put(K key, V value) : 把指定的鍵與指定的值添加到Map集合中。

    public V remove(Object key) : 把指定的鍵 所對應的鍵值對元素 在Map集合中刪除,返回被刪除元素的 值。

    public V get(Object key) 根據指定的鍵,在Map集合中獲取對應的值。

    public Set<K> keySet() : 獲取Map集合中所有的鍵,存儲到Set集合中。

    public Set<Map.Entry<K,V>> entrySet() : 獲取到Map集合中所有的鍵值對對象的集合(Set集合)。

 1 package demosummary.map;
 2 
 3 import java.util.HashMap;
 4 import java.util.Map;
 5 import java.util.Set;
 6 
 7 /**
 8  *       public V put(K key, V value) : 把指定的鍵與指定的值添加到Map集合中。
 9  *
10  *     public V get(Object key) 根據指定的鍵,在Map集合中獲取對應的值。
11  *     
12  *       public V remove(Object key) : 把指定的鍵所對應的鍵值對元素在Map集合中刪除,返回被刪除元素的值。
13  *
14  *     public Set<K> keySet() : 獲取Map集合中所有的鍵,存儲到Set集合中。
15  *
16  *     public Set<Map.Entry<K,V>> entrySet() : 獲取到Map集合中所有的鍵值對對象的集合(Set集合)。
17  */
18 public class MapMethods {
19     public static void main(String[] args) {
20         /**
21          * public V put(K key, V value) : 把指定的鍵與指定的值添加到Map集合中。
22          */
23         //創建map集合
24         HashMap<String, String> map = new HashMap<>();
25         //添加元素
26         map.put("蠻王", "艾希");
27         map.put("蓋倫", "卡特琳娜");
28         map.put("卡牌", "寡婦");
29         //列印map集合
30         System.out.println(map);//{卡牌=寡婦, 蠻王=艾希, 蓋倫=卡特琳娜}
31 
32         /**
33          * public V get(Object key) 根據指定的鍵,在Map集合中獲取對應的值。
34          */
35         String result = map.get("蠻王");
36         System.out.println(result);//艾希
37 
38         /**
39          * public V remove(Object key) : 把指定的鍵所對應的鍵值對元素在Map集合中刪除,返回被刪除元素的值。
40          */
41         String result1 = map.remove("蠻王");
42         System.out.println(result1);//艾希
43         System.out.println(map);//{卡牌=寡婦, 蓋倫=卡特琳娜}
44 
45         /**
46          * public Set<K> keySet() : 獲取Map集合中所有的鍵,存儲到Set集合中。
47          */
48         Set<String> set = map.keySet();
49         System.out.println(set);//[卡牌, 蓋倫]
50 
51         /**
52          * public Set<Map.Entry<K,V>> entrySet() : 獲取到Map集合中所有的鍵值對對象的集合(Set集合)。
53          */
54         Set<Map.Entry<String, String>> set1 = map.entrySet();
55         System.out.println(set1);//[卡牌=寡婦, 蓋倫=卡特琳娜]
56 
57     }
58 }

    註意:使用put方法時,若指定的鍵(key)在集合中沒有,則沒有這個鍵對應的值,返回null,並把指定的鍵值添加到 集合中;若指定的鍵(key)在集合中存在,則返回值為集合中鍵對應的值(該值為替換前的值),並把指定鍵所對應的值,替換成指定的新值。

Map集合遍歷鍵找值方式

  鍵找值方式:即通過元素中的鍵,獲取鍵所對應的值

    分析步驟:
      1. 獲取Map中所有的鍵,由於鍵是唯一的,所以返回一個Set集合存儲所有的鍵。方法提示: keyset()

      2. 遍歷鍵的Set集合,得到每一個鍵。

      3. 根據鍵,獲取鍵所對應的值。方法提示: get(K key)

 1 package demosummary.map;
 2 
 3 import java.util.HashMap;
 4 import java.util.Set;
 5 
 6 public class MapFor {
 7     /**
 8      * 鍵找值方式:即通過元素中的鍵,獲取鍵所對應的值
 9      *      分析步驟:
10      *          1. 獲取Map中所有的鍵,由於鍵是唯一的,所以返回一個Set集合存儲所有的鍵。方法提示: keyset()
11      *          2. 遍歷鍵的Set集合,得到每一個鍵。
12      *          3. 根據鍵,獲取鍵所對應的值。方法提示: get(K key)
13      */
14     public static void main(String[] args) {
15         //創建map集合
16         HashMap<String, String> map = new HashMap<>();
17         //添加元素
18         map.put("蠻王", "艾希");
19         map.put("德瑪", "卡特琳娜");
20         map.put("卡牌", "寡婦");
21         //獲取鍵
22         Set<String> keys = map.keySet();
23         //遍歷鍵
24         for (String key : keys) {
25             //通過鍵獲取值
26             String s = map.get(key);
27             System.out.println(s);
28             /**
29              * 運行結果
30              * 寡婦
31              * 卡特琳娜
32              * 艾希
33              */
34         }
35     }
36 }

Entry鍵值對對象

  我們已經知道, Map 中存放的是兩種對象,一種稱為key(鍵),一種稱為value(值),它們在在 Map 中是一一對應關 系,這一對對象又稱做 Map 中的一個 Entry(項) 。 Entry 將鍵值對的對應關係封裝成了對象。即鍵值對對象,這 樣我們在遍歷 Map 集合時,就可以從每一個鍵值對( Entry )對象中獲取對應的鍵與對應的值。

  方法:

    public K getKey() :獲取Entry對象中的鍵。

    public V getValue() :獲取Entry對象中的值。 

  在Map集合中也提供了獲取所有Entry對象的方法: 

    public Set<Map.Entry<K,V>> entrySet() : 獲取到Map集合中所有的鍵值對對象的集合(Set集合)。 

  操作步驟與圖解:
    1. 獲取Map集合中,所有的鍵值對(Entry)對象,以Set集合形式返回。方法提示: entrySet() 。

    2. 遍歷包含鍵值對(Entry)對象的Set集合,得到每一個鍵值對(Entry)對象

    3. 通過鍵值對(Entry)對象,獲取Entry對象中的鍵與值。  方法提示: getkey() getValue()

 1 package demosummary.map;
 2 
 3 import java.util.HashMap;
 4 import java.util.Map;
 5 import java.util.Set;
 6 
 7 public class MapEntry {
 8     public static void main(String[] args) {
 9         //創建map集合
10         HashMap<String, String> map = new HashMap<>();
11         //添加元素
12         map.put("蠻王", "艾希");
13         map.put("德瑪", "卡特琳娜");
14         map.put("卡牌", "寡婦");
15         //獲取entry對象
16         Set<Map.Entry<String, String>> entrySet = map.entrySet();
17         //遍歷得到entry對象
18         for (Map.Entry<String, String> es : entrySet) {
19             String key = es.getKey();
20             String value = es.getValue();
21             System.out.println(key + "的CP是" + value);
22             /**
23              * 執行結果
24              * 卡牌的CP是寡婦
25              * 德瑪的CP是卡特琳娜
26              * 蠻王的CP是艾希
27              */
28         }
29     }
30 }

HashMap存儲自定義類型鍵值

  

 1 package demosummary.map;
 2 
 3 import java.util.HashMap;
 4 import java.util.Objects;
 5 import java.util.Set;
 6 
 7 public class MapStudent {
 8     private String name;
 9     private Integer age;
10 
11     public MapStudent() {
12     }
13 
14     public MapStudent(String name, Integer age) {
15         this.name = name;
16         this.age = age;
17     }
18 
19     public String getName() {
20         return name;
21     }
22 
23     public void setName(String name) {
24         this.name = name;
25     }
26 
27     public Integer getAge() {
28         return age;
29     }
30 
31     public void setAge(Integer age) {
32         this.age = age;
33     }
34 
35     @Override
36     public boolean equals(Object o) {
37         if (this == o) return true;
38         if (o == null || getClass() != o.getClass()) return false;
39         MapStudent that = (MapStudent) o;
40         return Objects.equals(name, that.name) &&
41                 Objects.equals(age, that.age);
42     }
43 
44     @Override
45     public int hashCode() {
46         return Objects.hash(name, age);
47     }
48 
49     @Override
50     public String toString() {
51         return "MapStudent{" +
52                 "name='" + name + '\'' +
53                 ", age=" + age +
54                 '}';
55     }
56 
57     public static void main(String[] args) {
58         //創建HashMap集合對象
59         HashMap<MapStudent, String> map = new HashMap<>();
60         //添加元素
61         map.put(new MapStudent("A", 20),"北京");
62         map.put(new MapStudent("B", 21),"上海");
63         map.put(new MapStudent("C", 22),"深圳");
64         map.put(new MapStudent("D", 20),"廣州");
65         //獲取keySet對象
66         Set<MapStudent> ms = map.keySet();
67         //遍歷得到的Key
68         for (MapStudent m : ms) {
69             String s = map.get(m);
70             System.out.println(s);
71         }
72         /**
73          * 執行結果
74          * 廣州
75          * 北京
76          * 上海
77          * 深圳
78          */
79     }
80 }

 LinkedHashMap 

  LinkedHashMap可以保證存進去的元素有序,因為在HashMap下麵有一個子類LinkedHashMap,它是鏈表和哈希表組合的一個數據存儲結構

 1 package demosummary.map;
 2 
 3 import java.util.LinkedHashMap;
 4 import java.util.Map;
 5 import java.util.Set;
 6 
 7 public class LinkedMapDemo {
 8     public static void main(String[] args) {
 9         //創建LinkedHashMap集合
10         LinkedHashMap<String, String> map = new LinkedHashMap<>();
11         //添加元素
12         map.put("蠻王", "艾希");
13         map.put("德瑪", "卡特琳娜");
14         map.put("卡牌", "寡婦");
15         //獲取entrySet對象
16         Set<Map.Entry<String, String>> me = map.entrySet();
17         //遍歷獲取的鍵
18         for (Map.Entry<String, String> sse : me) {
19             System.out.println(sse.getKey()+"=="+sse.getValue());
20         }
21         /**
22          * 執行結果
23          * 蠻王==艾希
24          * 德瑪==卡特琳娜
25          * 卡牌==寡婦
26          */
27     }
28 }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 中間件是什麼呢? 中間件就是客戶端http請求發起傳送到伺服器和伺服器返迴響應之間的一些處理函數。 為什麼要使用中間件? 通過中間件,可以對數據進行操作使得我們能方便地操作請求數據編寫伺服器響應。如body-parse中間件對post請求的參數進行處理讓我們可以通過res.body快速獲取請求參數, ...
  • 一、項目簡介 uni-liveShow是一個基於vue+uni-app技術開發的集小視頻/IM聊天/直播等功能於一體的微直播項目。界面仿製抖音|火山小視頻/陌陌直播,支持編譯到多端(H5、小程式、App端) 且相容效果一致。 二、效果預覽 在H5、小程式、App端測試效果如下:(後續大圖均為APP端 ...
  • 最近在工作中遇到了一個百度地圖api中的難題,恐怕有的程式員可能也遇到過。就是實時定位並顯示軌跡,網上大部分都是通過創建polyline對象貼到地圖上。當然,百度地圖的畫線就是這樣實現的,但是好多人會發現,如果數據量超過四五千的話,瀏覽器可能就要卡了,後面可能就直接因為瀏覽器記憶體不足直接崩潰。按理講 ...
  • 文字摺疊效果 1. 效果展示 2. 實現過程 ~~~html H e l l o W o r l d ~~~ 填充內容 CSS佈局 ~~~css { margin:0px; padding:0px; } body{ background color:aquamarine; width:100%; h ...
  • 1.什麼是window? window:是一個全局對象, 代表瀏覽器中一個打開的視窗, 每個視窗都是一個window對象2.什麼是document? document是window的一個屬性, 這個屬性是一個對象 document: 代表當前視窗中的整個網頁, document對象保存了網頁上所有的 ...
  • 本節說一下DOM操作模塊里的複製元素子模塊,該模塊可以複製一個DOM節點,並且可選擇的設置是否複製其數據緩存對象(包含事件信息)和是否深度複製(子孫節點等),API如下: $.clone(elem, dataAndEvents, deepDataAndEvents) ;jQuery底層方法,返回DO ...
  • 場景 Nginx配置實例-負載均衡實例:平均訪問多台伺服器: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/103019576 在上面實現了負載均衡的簡單實例,平均訪問兩個伺服器。 但是如果不想使其平均訪問,有哪些常用的分配伺服器 ...
  • 場景 Nginx配置實例-反向代理實例:根據訪問的路徑跳轉到不同埠的服務中: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/102963715 在上個實例中,搭建好兩台tomcat伺服器。 負載均衡實現效果 瀏覽器輸入訪問地址, ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...