Java集合之HashMap用法詳解
本文實(shí)例講述了Java集合之HashMap用法。分享給大家供大家參考,具體如下:
HashMap是最常用的Map集合,它的鍵值對在存儲時要根據(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)文章
圖解Java經(jīng)典算法冒泡選擇插入希爾排序的原理與實(shí)現(xiàn)
冒泡排序是一種簡單的排序算法,它也是一種穩(wěn)定排序算法。其實(shí)現(xiàn)原理是重復(fù)掃描待排序序列,并比較每一對相鄰的元素,當(dāng)該對元素順序不正確時進(jìn)行交換。一直重復(fù)這個過程,直到?jīng)]有任何兩個相鄰元素可以交換,就表明完成了排序2022-09-09
JAVA并發(fā)編程有界緩存的實(shí)現(xiàn)詳解
這篇文章主要介紹了JAVA并發(fā)編程有界緩存的實(shí)現(xiàn)詳解的相關(guān)資料,這里舉例說明如何實(shí)現(xiàn),四種方法一一代碼實(shí)現(xiàn),需要的朋友可以參考下2016-12-12
從log4j切換到logback后項(xiàng)目無法啟動的問題及解決方法
這篇文章主要介紹了從log4j切換到logback后項(xiàng)目無法啟動的問題及解決方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-01-01
java如何判斷一個數(shù)是否是素數(shù)(質(zhì)數(shù))
這篇文章主要介紹了java如何判斷一個數(shù)是否是素數(shù)(質(zhì)數(shù)),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09
Springmvc conver實(shí)現(xiàn)原理及用法解析
這篇文章主要介紹了Springmvc conver實(shí)現(xiàn)原理及用法解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-10-10
Mybatis實(shí)現(xiàn)數(shù)據(jù)的增刪改查實(shí)例(CRUD)
本篇文章主要介紹了Mybatis實(shí)現(xiàn)數(shù)據(jù)的增刪改查實(shí)例(CRUD),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05
Java實(shí)現(xiàn)等待所有子線程結(jié)束后再執(zhí)行一段代碼的方法
這篇文章主要介紹了Java實(shí)現(xiàn)等待所有子線程結(jié)束后再執(zhí)行一段代碼的方法,涉及java多線程的線程等待與執(zhí)行等相關(guān)操作技巧,需要的朋友可以參考下2017-08-08
解決Eclipse發(fā)布到Tomcat丟失依賴jar包的問題
這篇文章介紹了如何在Eclipse中配置部署裝配功能,以確保在將Web項(xiàng)目發(fā)布到Tomcat服務(wù)器時不會丟失任何依賴jar包,通過手動配置或使用構(gòu)建工具腳本,可以自動化這個過程,提高開發(fā)效率和應(yīng)用程序的穩(wěn)定性,感興趣的朋友跟隨小編一起看看吧2025-01-01
Mybatis分頁插件Pagehelper的PageInfo字段屬性使用及解釋
這篇文章主要介紹了Mybatis分頁插件Pagehelper的PageInfo字段屬性使用及解釋,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-05-05

