溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Java那點(diǎn)兒事之Map集合有什么不為人知的秘密

發(fā)布時(shí)間:2021-10-21 15:04:18 來源:億速云 閱讀:105 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容主要講解“Java那點(diǎn)兒事之Map集合有什么不為人知的秘密”,感興趣的朋友不妨來看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“Java那點(diǎn)兒事之Map集合有什么不為人知的秘密”吧!

一、Map

Map集合的特點(diǎn)
- 鍵值對(duì)映射關(guān)系
- 一個(gè)鍵對(duì)應(yīng)一個(gè)值
- 鍵不能重復(fù),值可以重復(fù)
- 元素存取無序

我們通過他的一個(gè)實(shí)現(xiàn)類HashMap集合來理解

二、HashMap的基本概念

HashMap的定義:

HashMap 是一個(gè)散列表,它存儲(chǔ)的內(nèi)容是鍵值對(duì)(key-value)映射。

HashMap 實(shí)現(xiàn)了 Map 接口,根據(jù)鍵的 HashCode 值存儲(chǔ)數(shù)據(jù),具有很快的訪問速度,最多允許一條記錄的鍵為 null,不支持線程同步。

HashMap 是無序的,即不會(huì)記錄插入的順序。

HashMap 繼承于AbstractMap,實(shí)現(xiàn)了 Map、Cloneable、java.io.Serializable 接口。

Java那點(diǎn)兒事之Map集合有什么不為人知的秘密

那么HashMap的鍵和值的類型可以是String類型,也可以是其他數(shù)據(jù)的包裝類類型,那么說到包裝類類型,這里順便幫大家復(fù)習(xí)一下包裝類類型哦:

Java那點(diǎn)兒事之Map集合有什么不為人知的秘密

Java那點(diǎn)兒事之Map集合有什么不為人知的秘密

三、HashMap集合的基本方法與使用

學(xué)完HashMap集合的基本概念,那么我們?cè)趺慈ピ趯?shí)際開發(fā)過程中去使用他呢?這里我們就要用到他的特有方法了,

以下是HashMap集合的常用方法

Java那點(diǎn)兒事之Map集合有什么不為人知的秘密

需要注意的是,Map集合的元素的添加并不是Collection集合的add()方法,而是Put()方法。因?yàn)镸ap集合是鍵值對(duì)集合,那么我們?nèi)绾潍@取集合中的每一個(gè)元素呢?這里集合也給我們提供了他的元素獲取方法:

Java那點(diǎn)兒事之Map集合有什么不為人知的秘密

示例代碼如下:

import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
 
/*
    Map集合的獲取功能:
        V get(Object key):根據(jù)鍵獲取值
        Set<K> keySet():獲取所有鍵的集合
        Collection<V> values():獲取所有值的集合
 */
public class MapDemo03 {
    public static void main(String[] args) {
        Map<String, String> m = new HashMap<String, String>();
 
        m.put("張三", "李四");
        m.put("王五", "趙六");
        m.put("李老板", "光頭強(qiáng)");
        // V get(Object key):根據(jù)鍵獲取值
        System.out.println(m.get("張三"));
 
        System.out.println(m.get("張四"));
        System.out.println("=============");
 
        //        Set<K> keySet():獲取所有鍵的集合
        Set<String> s = m.keySet();
        for (String i : s) {
            System.out.println(i);
        }
        System.out.println("=============");
 
        //        Collection<V> values():獲取所有值的集合
        Collection<String> c = m.values();
        for (String x : c) {
            System.out.println(x);
        }
    }
}

輸出結(jié)果:

李四
null
=============
張三
王五
李老板
=============
李四
趙六
光頭強(qiáng)

四、HashMap集合的遍歷

其實(shí)遍歷無非就是把集合中的元素一個(gè)一個(gè)給取出來,我們能用,那么在第三部分其實(shí)就已經(jīng)講到了一種遍歷方式,那就是我們?nèi)カ@取鍵的集合,然后用循環(huán)去獲取每一個(gè)鍵所對(duì)應(yīng)的值,這樣我們就將集合中的每一個(gè)元素取出來了。

遍歷方式一:根據(jù)鍵的集合找值

步驟分析
- 獲取所有鍵的集合。用keySet()方法實(shí)現(xiàn)
- 遍歷鍵的集合,獲取到每一個(gè)鍵。用增強(qiáng)for實(shí)現(xiàn)
- 根據(jù)鍵去找值。用get(Object key)方法實(shí)現(xiàn)

代碼實(shí)現(xiàn)

import java.util.Map;
import java.util.HashMap;
import java.util.Set;
 
/*
    Map集合的遍歷(方式1):
        1:獲取所有鍵的集合。用keySet()方法實(shí)現(xiàn)
        2:遍歷鍵的集合,獲取到每一個(gè)鍵。用增強(qiáng)for實(shí)現(xiàn)
        3:根據(jù)鍵去找值。用get(Object key)方法實(shí)現(xiàn)
 */
public class MapDemo01 {
    public static void main(String[] args) {
        //創(chuàng)建集合對(duì)象
        Map<String, String> map = new HashMap<String, String>();
 
        //添加元素
        map.put("張無忌", "趙敏");
        map.put("郭靖", "黃蓉");
        map.put("楊過", "小龍女");
        //1:獲取所有鍵的集合。用keySet()方法實(shí)現(xiàn)
        Set<String> keySet = map.keySet();
 
        for (String key : keySet) {
            String value = map.get(key);
            System.out.println(key + "," + value);
        }
 
    }
}

輸出結(jié)果:

楊過,小龍女
郭靖,黃蓉
張無忌,趙敏

那么第二種方法就是我們利用entrySet()方法來獲取集合中所有的鍵值對(duì)集合,然后去獲取所對(duì)的鍵或值。

HashMap集合遍歷方式二:鍵值對(duì)集合找鍵值對(duì)

步驟分析
- 獲取所有鍵值對(duì)對(duì)象的集合
- Set<Map.Entry<K,V>> entrySet():獲取所有鍵值對(duì)對(duì)象的集合
- 遍歷鍵值對(duì)對(duì)象的集合,得到每一個(gè)鍵值對(duì)對(duì)象
- 用增強(qiáng)for實(shí)現(xiàn),得到每一個(gè)Map.Entry
- 根據(jù)鍵值對(duì)對(duì)象獲取鍵和值
- 用getKey()得到鍵
- 用getValue()得到值

代碼實(shí)現(xiàn)

import java.util.HashMap;
import java.util.Map;
import java.util.Set;
 
/*
    Map集合的遍歷(方式2):
        1:獲取所有鍵值對(duì)對(duì)象的集合
            Set<Map.Entry<K,V>> entrySet():獲取所有鍵值對(duì)對(duì)象的集合
        2:遍歷鍵值對(duì)對(duì)象的集合,得到每一個(gè)鍵值對(duì)對(duì)象
            用增強(qiáng)for實(shí)現(xiàn),得到每一個(gè)Map.Entry
        3:根據(jù)鍵值對(duì)對(duì)象獲取鍵和值
            用getKey()得到鍵
            用getValue()得到值
 */
public class MapDemo02 {
    public static void main(String[] args) {
        //創(chuàng)建集合對(duì)象
        Map<String, String> map = new HashMap<String, String>();
 
        //添加元素
        map.put("張無忌", "趙敏");
        map.put("郭靖", "黃蓉");
        map.put("楊過", "小龍女");
 
        //1:獲取所有鍵值對(duì)對(duì)象的集合
        Set<Map.Entry<String, String>> me = map.entrySet();
 
//        遍歷鍵值對(duì)對(duì)象的集合,得到每一個(gè)鍵值對(duì)對(duì)象
        for (Map.Entry<String, String> e : me) {
            String key = e.getKey();
            String value = e.getValue();
            System.out.println(key + "," + value);
        }
 
    }
}

輸出結(jié)果:

楊過,小龍女
郭靖,黃蓉
張無忌,趙敏

兩種遍歷方式都是很實(shí)用,各位大佬在開發(fā)中愿意用哪種都是可以的哦。

五、HashMap集合的綜合案例

有道是:與其臨淵羨魚,不如退而結(jié)網(wǎng)。看了那么 多理論的東西不自己動(dòng)手去實(shí)踐一下,那么魚兒永遠(yuǎn)在魚塘,知識(shí)永遠(yuǎn)在電腦里,接下來就讓我們一起動(dòng)手做一道題,來加深一下印象。

案例需求:

案例需求
- 鍵盤錄入一個(gè)字符串,要求統(tǒng)計(jì)字符串中每個(gè)字符串出現(xiàn)的次數(shù)。
- 舉例:鍵盤錄入“aababcabcdabcde” 在控制臺(tái)輸出:“a(5)b(4)c(3)d(2)e(1)”

思路解析:

1:鍵盤錄入一個(gè)字符串
2:創(chuàng)建HashMap集合,鍵是Character,值是Integer
3:遍歷字符串,得到每一個(gè)字符
4:拿得到的每一個(gè)字符作為鍵到HashMap集合中去找對(duì)應(yīng)的值,看其返回值
如果返回值是null:說明該字符在HashMap集合中不存在,就把該字符作為鍵,1作為值存儲(chǔ)
如果返回值不是null:說明該字符在HashMap集合中存在,把該值加1,然后重新存儲(chǔ)該字符和對(duì)應(yīng)的值
5:遍歷HashMap集合,得到鍵和值,按照要求進(jìn)行拼接
6:輸出結(jié)果

代碼實(shí)例:

import java.util.HashMap;
import java.util.Scanner;
import java.util.Set;
 
/*
    需求:
        鍵盤錄入一個(gè)字符串,要求統(tǒng)計(jì)字符串中每個(gè)字符串出現(xiàn)的次數(shù)。
        舉例:鍵盤錄入“aababcabcdabcde”	在控制臺(tái)輸出:“a(5)b(4)c(3)d(2)e(1)”
    思路:
        1:鍵盤錄入一個(gè)字符串
        2:創(chuàng)建HashMap集合,鍵是Character,值是Integer
        3:遍歷字符串,得到每一個(gè)字符
        4:拿得到的每一個(gè)字符作為鍵到HashMap集合中去找對(duì)應(yīng)的值,看其返回值
            如果返回值是null:說明該字符在HashMap集合中不存在,就把該字符作為鍵,1作為值存儲(chǔ)
            如果返回值不是null:說明該字符在HashMap集合中存在,把該值加1,然后重新存儲(chǔ)該字符和對(duì)應(yīng)的值
        5:遍歷HashMap集合,得到鍵和值,按照要求進(jìn)行拼接
        6:輸出結(jié)果
 */
public class HashMapDemo {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        System.out.println("請(qǐng)輸入一個(gè)字符串:");
        String s = sc.nextLine();
 
        HashMap<Character, Integer> hm = new HashMap<Character, Integer>();
 
        for (int i = 0; i < s.length(); i++) {
            char key = s.charAt(i);
 
            Integer value = hm.get(key);
            if (value == null) {
                hm.put(key, 1);
 
            } else {
                value++;
                hm.put(key, value);
            }
        }
 
        StringBuilder sb = new StringBuilder();
 
        Set<Character> keySet = hm.keySet();
        for (Character key1 : keySet) {
            Integer values = hm.get(key1);
            sb.append(key1).append("(").append(values).append(")");
        }
        String result = sb.toString();
        System.out.println(result);
    }
}

輸出結(jié)果:

請(qǐng)輸入一個(gè)字符串:
aababcabcdabcde
a(5)b(4)c(3)d(2)e(1)

到此,相信大家對(duì)“Java那點(diǎn)兒事之Map集合有什么不為人知的秘密”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI