如果哈希鍵中已經(jīng)存在該鍵,則Java HashMap computeIfPresent()方法將計(jì)算一個(gè)新值并將其與指定的鍵相關(guān)聯(lián)。
computeIfPresent()方法的語(yǔ)法為:
hashmap.computeIfPresent(K key, BiFunction remappingFunction)
computeIfPresent()方法有兩個(gè)參數(shù):
key - 與計(jì)算值關(guān)聯(lián)的鍵
remappingFunction - 為指定鍵計(jì)算新值的函數(shù)
注意:remappingFunction可以接受兩個(gè)參數(shù)。
返回與指定鍵關(guān)聯(lián)的新值
如果沒有與鍵關(guān)聯(lián)的值,則返回null
注意:如果remappingFunction結(jié)果為null,則將刪除指定鍵的映射。
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)映射到哈希映射中的值。
如果哈希表中不存在該鍵,則無(wú)法使用computeIfPresent()方法。
推薦閱讀
HashMap compute() - 計(jì)算指定鍵的值
HashMap computeIfAbsent() - 如果指定鍵未映射到任何值,則計(jì)算該值
Java HashMap merge() - 與compute()執(zhí)行相同的任務(wù)