Java Map循環指南

一、遍歷Map的三種方法

Java中的Map是一種以鍵值對形式存儲數據的容器,常用的實現類有HashMap、LinkedHashMap和TreeMap。遍歷Map是我們在使用Map時最常遇到的問題之一,下面介紹三種常用的遍歷方法。

1. 通過entrySet遍歷

Map map = new HashMap();
map.put(1, "one");
map.put(2, "two");
map.put(3, "three");

for (Map.Entry entry : map.entrySet()) {
    System.out.println(entry.getKey() + " " + entry.getValue());
}

使用entrySet遍歷時,先獲取到Map的所有entry集合,然後遍歷所有entry,通過entry的getKey和getValue方法獲取鍵值對。

2. 通過keySet遍歷

Map map = new HashMap();
map.put(1, "one");
map.put(2, "two");
map.put(3, "three");

for (Integer key : map.keySet()) {
    System.out.print(key + " ");
    System.out.println(map.get(key));
}

使用keySet遍歷時,先獲取到Map的所有key集合,然後遍歷所有key,通過Map的get方法獲取對應的值。

3. 通過values遍歷

Map map = new HashMap();
map.put(1, "one");
map.put(2, "two");
map.put(3, "three");

for (String value : map.values()) {
    System.out.println(value);
}

使用values遍歷時,直接獲取到Map的所有值的集合,然後遍歷所有值。

二、如何遍歷有序Map

有序Map是指像LinkedHashMap和TreeMap這樣的實現類,能夠按照某種順序(通常是插入順序或按照鍵的自然順序)存儲鍵值對。如何遍歷這些有序Map呢?

其實原理和遍歷HashMap一樣,只是在創建實例時需要指定排序的方式。

1. LinkedHashMap

Map map = new LinkedHashMap(16, 0.75f, true);
map.put(1, "one");
map.put(2, "two");
map.put(3, "three");

for (Map.Entry entry : map.entrySet()) {
    System.out.println(entry.getKey() + " " + entry.getValue());
}

在創建LinkedHashMap時,需要傳入三個參數:initialCapacity(初始化容量)、loadFactor(負載因子)和accessOrder(排序方式)。accessOrder為true時表示按照訪問順序排序,為false時表示按照插入順序排序。

2. TreeMap

Map map = new TreeMap();
map.put(1, "one");
map.put(2, "two");
map.put(3, "three");

for (Map.Entry entry : map.entrySet()) {
    System.out.println(entry.getKey() + " " + entry.getValue());
}

在創建TreeMap時,只需要像創建普通HashMap一樣傳入默認的初始化容量即可。

三、遍歷Map的性能比較

不同的遍歷方式對Map的性能有影響,下面通過實驗來看看它們之間的性能差異。

實驗代碼如下:

Map map = new HashMap();
Random random = new Random();
for (int i = 0; i < 1000000; i++) {
    map.put(random.nextInt(1000000), "some value");
}

long start = System.currentTimeMillis();
for (Map.Entry entry : map.entrySet()) {
    // do nothing
}
long end = System.currentTimeMillis();
System.out.println("遍歷entrySet耗時:" + (end - start) + "ms");

start = System.currentTimeMillis();
for (Integer key : map.keySet()) {
    // do nothing
}
end = System.currentTimeMillis();
System.out.println("遍歷keySet耗時:" + (end - start) + "ms");

start = System.currentTimeMillis();
for (String value : map.values()) {
    // do nothing
}
end = System.currentTimeMillis();
System.out.println("遍歷values耗時:" + (end - start) + "ms");

實驗結果(遍歷1000000個元素,單位:毫秒):

遍歷entrySet耗時:14ms

遍歷keySet耗時:16ms

遍歷values耗時:33ms

從實驗結果來看,通過entrySet遍歷Map是最快的,而通過values遍歷是最慢的。

四、如何在多線程環境下遍歷Map

在多線程環境下使用Map時,遍歷是一個非常常見的操作,但是需要注意線程安全問題。

如果只是讀取操作,可以直接使用Java 8中的forEach方法,示例代碼如下:

Map map = new ConcurrentHashMap();
map.put(1, "one");
map.put(2, "two");
map.put(3, "three");

map.forEach((key, value) -> {
    System.out.println(key + " " + value);
});

如果同時存在讀取和寫入操作,可以使用並發安全的遍歷方式,如下代碼所示:

Map map = new ConcurrentHashMap();
map.put(1, "one");
map.put(2, "two");
map.put(3, "three");

map.entrySet().parallelStream().forEach(entry -> {
    System.out.println(entry.getKey() + " " + entry.getValue());
});

使用parallelStream遍歷Map時,底層會自動實現並發安全,處理速度也會更快。

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

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-11-11 13:42
下一篇 2024-11-11 13:42

相關推薦

  • 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
  • 運維Python和GO應用實踐指南

    本文將從多個角度詳細闡述運維Python和GO的實際應用,包括監控、管理、自動化、部署、持續集成等方面。 一、監控 運維中的監控是保證系統穩定性的重要手段。Python和GO都有強…

    編程 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
  • Python wordcloud入門指南

    如何在Python中使用wordcloud庫生成文字雲? 一、安裝和導入wordcloud庫 在使用wordcloud前,需要保證庫已經安裝並導入: !pip install wo…

    編程 2025-04-29
  • Python應用程序的全面指南

    Python是一種功能強大而簡單易學的編程語言,適用於多種應用場景。本篇文章將從多個方面介紹Python如何應用於開發應用程序。 一、Web應用程序 目前,基於Python的Web…

    編程 2025-04-29
  • Python小波分解入門指南

    本文將介紹Python小波分解的概念、基本原理和實現方法,幫助初學者掌握相關技能。 一、小波變換概述 小波分解是一種廣泛應用於數字信號處理和圖像處理的方法,可以將信號分解成多個具有…

    編程 2025-04-29
  • Python字元轉列表指南

    Python是一個極為流行的腳本語言,在數據處理、數據分析、人工智慧等領域廣泛應用。在很多場景下需要將字元串轉換為列表,以便於操作和處理,本篇文章將從多個方面對Python字元轉列…

    編程 2025-04-29

發表回復

登錄後才能評論