程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> Java集合之HashMap用法詳解

Java集合之HashMap用法詳解

編輯:關於JAVA

本文實例講述了Java集合之HashMap用法。分享給大家供大家參考,具體如下:

HashMap是最常用的Map集合,它的鍵值對在存儲時要根據鍵的哈希碼來確定值放在哪裡。

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"); //可以運行鍵值都為空(如果鍵相同,後者覆蓋前者)
    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()); //不包含鍵-值映射關系,則返回true
    map.remove(5); //刪除映射關系
    System.out.println(map);
    map.clear();//清空集合
    System.out.println(map);
  }
}

控制台結果:

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次,一次是轉為iterator,一次就從HashMap中取出key所對於的value。
    //對於entrySet只是遍歷了第一次,它把key和value都放到了entry中,所以快比keySet快些。
    System.out.println("For-Each循環輸出");
    //For-Each循環
    for (Map.Entry<String, Integer> entry:map.entrySet()) {
      String key = entry.getKey().toString();
      String val = entry.getValue().toString();
      System.out.println("鍵:"+key+"<==>"+"值:"+val);
    }
  }
}

控制台結果:

PS:這裡再為大家提供2款hash相關在線工具供大家參考使用:

在線散列/哈希算法加密工具:
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

更多關於java算法相關內容感興趣的讀者可查看本站專題:《Java數據結構與算法教程》、《Java操作DOM節點技巧總結》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》

希望本文所述對大家java程序設計有所幫助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved