如果哈希鍵中已經(jīng)存在該鍵,則Java HashMap computeIfPresent()方法將計(jì)算一個(gè)新值并將其與指定的鍵相關(guān)聯(lián)。
computeIfPresent()方法的語法為:
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)映射到哈希映射中的值。
如果哈希表中不存在該鍵,則無法使用computeIfPresent()方法。
推薦閱讀
HashMap compute() - 計(jì)算指定鍵的值
HashMap computeIfAbsent() - 如果指定鍵未映射到任何值,則計(jì)算該值
Java HashMap merge() - 與compute()執(zhí)行相同的任務(wù)