Java 菜鳥教程

Java 流程控制

Java 數(shù)組

Java 面向?qū)ο?I)

Java 面向?qū)ο?II)

Java 面向?qū)ο?III)

Java 異常處理

Java 列表(List)

Java Queue(隊(duì)列)

Java Map集合

Java Set集合

Java 輸入輸出(I/O)

Java Reader/Writer

Java 其他主題

Java HashMap computeIfPresent() 使用方法及示例

Java HashMap 方法

如果哈希鍵中已經(jīng)存在該鍵,則Java HashMap computeIfPresent()方法將計(jì)算一個(gè)新值并將其與指定的鍵相關(guān)聯(lián)。

computeIfPresent()方法的語法為:

hashmap.computeIfPresent(K key, BiFunction remappingFunction)

computeIfPresent()參數(shù)

computeIfPresent()方法有兩個(gè)參數(shù):

  • key - 與計(jì)算值關(guān)聯(lián)的鍵

  • remappingFunction - 為指定計(jì)算新值的函數(shù)

注意:remappingFunction可以接受兩個(gè)參數(shù)。

computeIfPresent()返回值

  • 返回與指定鍵關(guān)聯(lián)的新值

  • 如果沒有與鍵關(guān)聯(lián)的值,則返回null

注意:如果remappingFunction結(jié)果為null,則將刪除指定的映射。

示例1:Java HashMap的computeIfPresent()

import java.util.HashMap;

class Main {
  public static void main(String[] args) {
    // 創(chuàng)建 HashMap
    HashMap<String, Integer> prices = new HashMap<>();

    // 向HashMap插入條目
    prices.put("Shoes", 200);
    prices.put("Bag", 300);
    prices.put("Pant", 150);
    System.out.println("HashMap: " + prices);

    //用10%的增值稅重新計(jì)算鞋子的價(jià)值
    int shoesPrice = prices.computeIfPresent("Shoes", (key, value) -> value + value * 10/100);
    System.out.println("鞋子加上增值稅后的價(jià)格: " + shoesPrice);

    // 打印更新的HashMap
    System.out.println("更新后的 HashMap: " + prices);
  }
}

輸出結(jié)果

HashMap: {Pant=150, Bag=300, Shoes=200}
鞋子加上增值稅后的價(jià)格: 220
更新后的 HashMap: {Pant=150, Bag=300, Shoes=220}}

在上面的示例中,我們創(chuàng)建了一個(gè)名為prices的哈希映射。注意表達(dá)式

prices.computeIfPresent("Shoes", (key, value) -> value + value * 10/100)

這里,

  • (key, value) -> value + value*10/100  - 是lambda表達(dá)式。它計(jì)算Shoes的新值并返回。要了解有關(guān)lambda表達(dá)式的更多信息,請(qǐng)?jiān)L問Java Lambda 表達(dá)式。

  • prices.computeIfPresent()  - 將lambda表達(dá)式返回的新值與Shoes的映射關(guān)聯(lián)。這是唯一可能的,因?yàn)镾hoes已經(jīng)映射到哈希映射中的值。

如果哈希表中不存在該鍵,則無法使用computeIfPresent()方法。

推薦閱讀

Java HashMap 方法

丰满人妻一级特黄a大片,午夜无码免费福利一级,欧美亚洲精品在线,国产婷婷成人久久Av免费高清