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 方法