Java HashMap merge() 方法
示例
计算地图中条目的新值
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);
}
}
定义和用法
The merge()
方法创建一个指定键和值的条目,或者如果已经存在指定键的条目,则计算条目的新值。
新值使用函数计算,该函数可以通过与 Java 的 BiFunction
接口的 apply()
方法兼容的 lambda 表达式定义。
要了解 lambda 表达式,请参阅我们的 Java Lambda 表达式教程.
语法
public V merge(K key, V value, BiFunction function)
K
和 V
指的是地图的键和值的类型。
参数值
参数 | 描述 |
---|---|
key | 必需。条目的键。 |
value | 必需。如果不存在指定键的条目,则使用该值。 |
function | 必需。一个 BiFunction 对象或 lambda 表达式,它对每个条目进行操作。函数的第一个参数包含条目的当前值,第二个参数包含value参数指定的值。 |
技术细节
返回值 | 写入条目的值。 |
---|
相关页面
❮ HashMap 方法