Java Map Remove詳解

一、Map.remove()

Map.remove(Object key)方法用於根據key刪除Map中的entry。如果Map中不存在這個key,則不進行任何操作。remove()方法在執行刪除操作後會返回被刪除的value值,或是null。

Map map = new HashMap();
map.put(1, "a");
String value = map.remove(1);
System.out.println(value); // 輸出a
System.out.println(map.containsKey(1)); // 輸出false

上面代碼中,通過remove()方法刪除了key為1的entry,並返回了對應的value值”a”。使用containsKey()方法查看發現在Map中已經不存在key為1的entry,返回false。

二、Map.remove()用法小技巧

1. 使用remove()方法批量刪除符合條件entries

remove()方法不僅可以刪除單個entry,還可以用於批量刪除符合條件的entries。可以通過循環遍歷或Java 8中的stream()方法實現。

// 循環遍歷刪除
Map map = new HashMap();
for (Iterator<Map.Entry> it = map.entrySet().iterator(); it.hasNext(); ) {
    Map.Entry entry = it.next();
    if (entry.getValue() == 0) {
        it.remove();
    }
}

// Java 8中的stream()方法實現
Map map = new HashMap();
map.entrySet().removeIf(entry -> entry.getValue() == 0);

上述代碼中,使用removeIf()方法批量刪除value為0的entry。

2. 使用remove()方法實現LRU緩存淘汰策略

LRU(Least Recently Used)緩存淘汰策略是指在緩存容量不夠時,優先刪除使用時間距離當前時間最久的entry。可以使用LinkedHashMap實現LRU緩存淘汰策略,LinkedHashMap繼承自HashMap,內部是由一個linked list實現的,它保留了entry插入的順序。

public class LRUCache extends LinkedHashMap {
    private final int maxEntries;
    public LRUCache(int maxEntries) {
        super(16, 0.75f, true);
        this.maxEntries = maxEntries;
    }
    // LinkedHashMap自帶的刪除最舊entry的辦法,被覆蓋時會調用這個方法
    protected boolean removeEldestEntry(Map.Entry eldest) {
        return size() > maxEntries;
    }
}

// 測試使用
LRUCache map = new LRUCache(2);
map.put(1, 1);
map.put(2, 2);
map.put(3, 3);
map.put(4, 4);
System.out.println(map);

在上述代碼中,定義了一個LRUCache類,它繼承自LinkedHashMap,並覆蓋了removeEldestEntry()方法,實現LRU緩存淘汰策略。在測試使用時,map容量為2,但是存放了4個entry,因此會自動刪除最久未使用的entry。

三、注意事項

1. Java集合類本身不是線程安全的

Java中的集合類本身是不具備線程安全性的,因為多個線程同時修改集合中的entry時,存在同時讀寫集合的問題。因此,在並發環境中使用集合類時,需要通過加鎖或並發包提供的類來保證線程安全。

2. 在遍歷集合時,不要使用循環表達式中的remove()方法

使用循環表達式中的remove()方法刪除entry會導致遍歷集合出現異常或遺漏元素。因為在使用remove()方法刪除entry後,下一個元素會頂替刪除的元素,因此遍歷時可能會跳過頂替位置變化後的元素。

最後,上面提到的LRU緩存淘汰策略在Java 8中還可以通過Java 8提供的LinkedHashMap的一些新特性很好地實現,感興趣的可以自己去了解。

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

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
QKTNT的頭像QKTNT
上一篇 2025-04-18 13:40
下一篇 2025-04-18 13:40

相關推薦

  • Java JsonPath 效率優化指南

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

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

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

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

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

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

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

    編程 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
  • Java 8 Group By 會影響排序嗎?

    是的,Java 8中的Group By會對排序產生影響。本文將從多個方面探討Group By對排序的影響。 一、Group By的概述 Group By是SQL中的一種常見操作,它…

    編程 2025-04-29

發表回復

登錄後才能評論