Java集合之HashMap用法詳解
本文實(shí)例講述了Java集合之HashMap用法。分享給大家供大家參考,具體如下:
HashMap是最常用的Map集合,它的鍵值對在存儲時(shí)要根據(jù)鍵的哈希碼來確定值放在哪里。
HashMap 中作為鍵的對象必須重寫Object的hashCode()
方法和equals()
方法
import java.util.Map; import java.util.HashMap; public class lzwCode { public static void main(String [] args) { Map<Integer, String> map = new HashMap<Integer, String>(); map.put(1, "Barcelona"); map.put(2, "RealMadrid"); map.put(3, "ManchesterUnited"); map.put(4, "AC milan"); map.put(5, null); map.put(null, null); //map.put(null, "Chelsea"); //可以運(yùn)行鍵值都為空(如果鍵相同,后者覆蓋前者) System.out.println(map); System.out.print(map.keySet()+" "); //集合中所有鍵以Set集合形式返回 System.out.println(); System.out.print(map.values()+" "); //集合中所有鍵以Collection集合形式返回 System.out.println(); System.out.println("集合大小:"+map.size()); System.out.println("是否包含該鍵:"+map.containsKey(2));//返回boolean System.out.println("是否包含該值:"+map.containsValue("Barcelona"));//返回boolean System.out.println(map.isEmpty()); //不包含鍵-值映射關(guān)系,則返回true map.remove(5); //刪除映射關(guān)系 System.out.println(map); map.clear();//清空集合 System.out.println(map); } }
控制臺結(jié)果:
HashMap的兩種遍歷方法
import java.util.Map; import java.util.HashMap; import java.util.Iterator; public class lzwCode { public static void main(String [] args) { Map<String, Integer> map = new HashMap<String, Integer>(); map.put("Barcelona", 1); map.put("RealMadrid", 2); map.put("ManchesterUnited", 3); map.put("AC milan", 4); map.put("Chelsea", 5); //第一種:(效率高) System.out.println("第一種方法:"); Iterator iter = map.entrySet().iterator(); while (iter.hasNext()) { Map.Entry entry = (Map.Entry)iter.next(); Object key = entry.getKey(); Object val = entry.getValue(); System.out.println("鍵:"+key+"<==>"+"值:"+val); } //第二種:(效率低) System.out.println("第二種方法:"); Iterator it = map.keySet().iterator(); while (it.hasNext()) { Object key = it.next(); Object val = map.get(key); System.out.println("鍵:"+key+"<==>"+"值:"+val); } //對于keySet只是遍歷了2次,一次是轉(zhuǎn)為iterator,一次就從HashMap中取出key所對于的value。 //對于entrySet只是遍歷了第一次,它把key和value都放到了entry中,所以快比keySet快些。 System.out.println("For-Each循環(huán)輸出"); //For-Each循環(huán) for (Map.Entry<String, Integer> entry:map.entrySet()) { String key = entry.getKey().toString(); String val = entry.getValue().toString(); System.out.println("鍵:"+key+"<==>"+"值:"+val); } } }
控制臺結(jié)果:
PS:這里再為大家提供2款hash相關(guān)在線工具供大家參考使用:
在線散列/哈希算法加密工具:
http://tools.jb51.net/password/hash_encrypt
在線MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:
http://tools.jb51.net/password/hash_md5_sha
更多關(guān)于java算法相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java操作DOM節(jié)點(diǎn)技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》
希望本文所述對大家java程序設(shè)計(jì)有所幫助。
相關(guān)文章
Mybatisplus自動填充實(shí)現(xiàn)方式及代碼示例
這篇文章主要介紹了Mybatisplus自動填充實(shí)現(xiàn)方式及代碼示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11SpringBoot + WebSocket 實(shí)現(xiàn)答題對戰(zhàn)匹配機(jī)制案例詳解
這篇文章主要介紹了SpringBoot + WebSocket 實(shí)現(xiàn)答題對戰(zhàn)匹配機(jī)制,分別為每個(gè)用戶擬定四種在線狀態(tài),通過流程圖給大家展示,需要的朋友可以參考下2021-05-05Java獲取支付寶OpenID的實(shí)現(xiàn)方法
在Java中,通過支付寶開放平臺API可以獲取用戶的OpenID,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-09-09探討:使用httpClient在客戶端與服務(wù)器端傳輸對象參數(shù)的詳解
本篇文章是對使用httpClient在客戶端與服務(wù)器端傳輸對象參數(shù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06Spring?Boot在啟動時(shí)執(zhí)行一次的功能實(shí)現(xiàn)
這篇文章主要給大家介紹了關(guān)于Spring?Boot在啟動時(shí)執(zhí)行一次的功能實(shí)現(xiàn),在實(shí)習(xí)過程中,有時(shí)候會遇到一些項(xiàng)目啟動初始化的需求,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-08-08Java實(shí)現(xiàn)二分查找算法實(shí)例分析
這篇文章主要介紹了Java實(shí)現(xiàn)二分查找算法,實(shí)例分析了二分查找算法的原理與相關(guān)實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07SpringCloud Gateway的基本入門和注意點(diǎn)詳解
這篇文章主要介紹了SpringCloud Gateway的基本入門和注意點(diǎn),具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10