Java HashMap merge() 方法
示例
為 Map 中的條目計算一個新值
import java.util.HashMap;
public class Main {
public static void main(String[] args) {
HashMap<String, String> capitalCities = new HashMap<String, String>();
capitalCities.put("England", "London");
capitalCities.put("Germany", "Berlin");
capitalCities.put("Norway", "Oslo");
capitalCities.put("USA", "Washington DC");
capitalCities.merge("Canada", "Ottawa", (a, b) -> a + " -> " + b);
capitalCities.merge("England", "London", (a, b) -> a + " -> " + b);
capitalCities.merge("Germany", "Berlin", (a, b) -> a + " -> " + b);
System.out.println(capitalCities);
}
}
定義和用法
merge()
方法建立一個具有指定鍵和值的新條目,如果具有指定鍵的條目已存在,則計算該條目的新值。
新值使用一個函式計算,該函式可以透過與 Java 的 BiFunction
介面的 apply()
方法相容的 lambda 表示式定義。
要了解 lambda 表示式,請參閱我們的 Java Lambda 表示式教程。
語法
public V merge(K key, V value, BiFunction function)
K
和 V
指的是 Map 的鍵和值的資料型別。
引數值
引數 | 描述 |
---|---|
key | 必需。條目的鍵。 |
value | 必需。如果具有指定鍵的條目尚不存在,則使用的值。 |
function | 必需。一個對每個條目進行操作的 BiFunction 物件或 lambda 表示式。函式的第一個引數包含條目的當前值,第二個引數包含由 *value* 引數指定的值。 |
技術詳情
返回 | 寫入到條目中的值。 |
---|
相關頁面
❮ HashMap 方法