Java HashMap遍歷

一、HashMap簡介

HashMap是Java中的常用集合類,它實現了Map介面,提供了基於鍵值對的存儲和檢索功能。HashMap允許鍵和值都可以為空,而且是非線程安全的。

二、HashMap遍歷方式

1. 使用迭代器遍歷

HashMap<String, Integer> hashMap = new HashMap<>();
hashMap.put("Tom", 1);
hashMap.put("Jerry", 2);
Iterator iter = hashMap.entrySet().iterator();
while (iter.hasNext()) {
    Map.Entry entry = (Map.Entry) iter.next();
    String key = (String) entry.getKey();
    Integer value = (Integer) entry.getValue();
    System.out.println("key: " + key + ", value: " + value);
}

使用entrySet方法獲取HashMap的entry集合,然後通過迭代器遍歷集合,最後通過entry的getKey和getValue方法獲取鍵和值。

2. 使用foreach遍歷鍵

HashMap<String, Integer> hashMap = new HashMap<>();
hashMap.put("Tom", 1);
hashMap.put("Jerry", 2);
for (String key : hashMap.keySet()) {
    System.out.println("Key: " + key);
}

使用keySet方法獲取HashMap的鍵集合,然後通過foreach循環遍歷鍵。

3. 使用foreach遍歷值

HashMap<String, Integer> hashMap = new HashMap<>();
hashMap.put("Tom", 1);
hashMap.put("Jerry", 2);
for (Integer value : hashMap.values()) {
    System.out.println("Value: " + value);
}

使用values方法獲取HashMap的值集合,然後通過foreach循環遍歷值。

三、HashMap遍歷性能對比

在實際開發中,多個遍歷方式的性能是有差異的,根據遍歷方式的不同,HashMap的遍歷時間也不同。

下面我們通過代碼來測試三種遍歷方式的性能:

HashMap<Integer, Integer> hashMap = new HashMap<>();
for (int i = 1; i <= 1000000; i++) {
    hashMap.put(i, i);
}

long start = System.currentTimeMillis();
Iterator iter = hashMap.entrySet().iterator();
while (iter.hasNext()) {
    Map.Entry entry = (Map.Entry) iter.next();
    Integer key = (Integer) entry.getKey();
    Integer value = (Integer) entry.getValue();
}
long end = System.currentTimeMillis();
System.out.println("Iterator: " + (end - start) + "ms");

start = System.currentTimeMillis();
for (Integer key : hashMap.keySet()) {
    Integer value = hashMap.get(key);
}
end = System.currentTimeMillis();
System.out.println("Key Set: " + (end - start) + "ms");

start = System.currentTimeMillis();
for (Integer value : hashMap.values()) {
    Integer key = getKey(hashMap, value);
}
end = System.currentTimeMillis();
System.out.println("Value: " + (end - start) + "ms");

private static Integer getKey(HashMap<Integer, Integer> map, Integer value) {
    for (Integer key : map.keySet()) {
        if (value.equals(map.get(key))) {
            return key;
        }
    }
    return null;
}

在這個測試代碼中,我們生成了一個包含1000000個鍵值對的HashMap,然後分別使用迭代器、keySet和values遍歷方式,每種方式遍歷一次,統計遍歷時間。

可以看到,keySet和values的性能表現大致相同,比迭代器快一點。

四、HashMap遍歷總結

HashMap是Java中常用的集合類,提供基於鍵值對的存儲和檢索功能。三種遍歷方式分別是使用迭代器、keySet和values,其中後兩種性能較好。

開發者在使用HashMap並進行遍歷時要結合實際情況選擇最適合自己的方式。

原創文章,作者:VSVCH,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/333881.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
VSVCH的頭像VSVCH
上一篇 2025-02-01 13:34
下一篇 2025-02-01 13:34

相關推薦

  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • Java騰訊雲音視頻對接

    本文旨在從多個方面詳細闡述Java騰訊雲音視頻對接,提供完整的代碼示例。 一、騰訊雲音視頻介紹 騰訊雲音視頻服務(Cloud Tencent Real-Time Communica…

    編程 2025-04-29
  • Java Bean載入過程

    Java Bean載入過程涉及到類載入器、反射機制和Java虛擬機的執行過程。在本文中,將從這三個方面詳細闡述Java Bean載入的過程。 一、類載入器 類載入器是Java虛擬機…

    編程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介紹

    本文將詳細介紹Java Milvus SearchParam withoutFields的相關知識和用法。 一、什麼是Java Milvus SearchParam without…

    編程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java語言中的一個版本,於2014年3月18日發布。本文將從多個方面對Java 8中某一周的周一進行詳細的闡述。 一、數組處理 Java 8新特性之一是Stream…

    編程 2025-04-29
  • Java判斷字元串是否存在多個

    本文將從以下幾個方面詳細闡述如何使用Java判斷一個字元串中是否存在多個指定字元: 一、字元串遍歷 字元串是Java編程中非常重要的一種數據類型。要判斷字元串中是否存在多個指定字元…

    編程 2025-04-29
  • VSCode為什麼無法運行Java

    解答:VSCode無法運行Java是因為默認情況下,VSCode並沒有集成Java運行環境,需要手動添加Java運行環境或安裝相關插件才能實現Java代碼的編寫、調試和運行。 一、…

    編程 2025-04-29
  • Java任務下發回滾系統的設計與實現

    本文將介紹一個Java任務下發回滾系統的設計與實現。該系統可以用於執行複雜的任務,包括可回滾的任務,及時恢復任務失敗前的狀態。系統使用Java語言進行開發,可以支持多種類型的任務。…

    編程 2025-04-29
  • Python遍歷集合中的元素

    本文將從多個方面詳細闡述Python遍歷集合中的元素方法。 一、for循環遍歷集合 Python中,使用for循環可以遍歷集合中的每個元素,代碼如下: my_set = {1, 2…

    編程 2025-04-29

發表回復

登錄後才能評論