您好,登錄后才能下訂單哦!
這期內(nèi)容當(dāng)中小編將會給大家?guī)碛嘘P(guān)利用Java如何實(shí)現(xiàn)對HashMap的集合使用,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
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é)果:
上述就是小編為大家分享的利用Java如何實(shí)現(xiàn)對HashMap的集合使用了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。