您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“Java那點(diǎn)兒事之Map集合有什么不為人知的秘密”,感興趣的朋友不妨來看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“Java那點(diǎn)兒事之Map集合有什么不為人知的秘密”吧!
Map集合的特點(diǎn)
- 鍵值對(duì)映射關(guān)系
- 一個(gè)鍵對(duì)應(yīng)一個(gè)值
- 鍵不能重復(fù),值可以重復(fù)
- 元素存取無序
我們通過他的一個(gè)實(shí)現(xiàn)類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 接口。
那么HashMap的鍵和值的類型可以是String類型,也可以是其他數(shù)據(jù)的包裝類類型,那么說到包裝類類型,這里順便幫大家復(fù)習(xí)一下包裝類類型哦:
學(xué)完HashMap集合的基本概念,那么我們?cè)趺慈ピ趯?shí)際開發(fā)過程中去使用他呢?這里我們就要用到他的特有方法了,
以下是HashMap集合的常用方法
需要注意的是,Map集合的元素的添加并不是Collection集合的add()方法,而是Put()方法。因?yàn)镸ap集合是鍵值對(duì)集合,那么我們?nèi)绾潍@取集合中的每一個(gè)元素呢?這里集合也給我們提供了他的元素獲取方法:
示例代碼如下:
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)
其實(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ā)中愿意用哪種都是可以的哦。
有道是:與其臨淵羨魚,不如退而結(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í)!
免責(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)容。