merge() 方法会先判断指定的 key 是否存在,如果不存在,则添加键值对到 hashMap 中。
merge() 方法的语法为:
hashmap.merge(key, value, remappingFunction)
注:hashmap 是 HashMap 类的一个对象。
参数说明:
- key - 键
- value - 值
- remappingFunction - 重新映射函数,用于重新计算值
返回值
如果 key 对应的 value 不存在,则返回该 value 值,如果存在,则返回通过 remappingFunction 重新计算后的值。
实例
以下实例演示了 merge() 方法的使用:
实例
import java.util.HashMap;
class Main {
public static void main(String[] args) {
//创建一个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);
int returnedValue = prices.merge("Shirt", 100, (oldValue, newValue) -> oldValue + newValue);
System.out.println("Price of Shirt: " + returnedValue);
// 输出更新后的 HashMap
System.out.println("Updated HashMap: " + prices);
}
}
class Main {
public static void main(String[] args) {
//创建一个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);
int returnedValue = prices.merge("Shirt", 100, (oldValue, newValue) -> oldValue + newValue);
System.out.println("Price of Shirt: " + returnedValue);
// 输出更新后的 HashMap
System.out.println("Updated HashMap: " + prices);
}
}
执行以上程序输出结果为:
HashMap: {Pant=150, Bag=300, Shoes=200}Price of Shirt: 100Updated HashMap: {Pant=150, Shirt=100, Bag=300, Shoes=200}
在以上实例中,我们创建了一个名为 prices 的 HashMap。
注意表达式:
prices.merge("Shirt", 100, (oldValue, newValue) -> oldValue + newValue)
代码中,我们使用了匿名函数 lambda表达式 (oldValue, newValue) -> oldValue + newValue) 作为重新映射函数。
因为键 Shirt 并不在 prices 中,merge() 方法将映射 Shirt=100 插入到 prices,重新映射函数的执行结果被忽略。
要了解有关 lambda 表达式的更多信息,请访问 Java Lambda 表达式。
HashMap merge() 方法插入具有重复 key 的映射项:
实例
import java.util.HashMap;
class Main {
public static void main(String[] args) {
// 创建一个 HashMap
HashMap<String, String> countries = new HashMap<>();
// 往HashMap插入映射项
countries.put("Washington", "America");
countries.put("Canberra", "Australia");
countries.put("Madrid", "Spain");
System.out.println("HashMap: " + countries);
//合并 key为 Washington的映射
String returnedValue = countries.merge("Washington", "USA", (oldValue, newValue) -> oldValue + "/" + newValue);
System.out.println("Washington: " + returnedValue);
//输出更新后的HashMap
System.out.println("Updated HashMap: " + countries);
}
}
class Main {
public static void main(String[] args) {
// 创建一个 HashMap
HashMap<String, String> countries = new HashMap<>();
// 往HashMap插入映射项
countries.put("Washington", "America");
countries.put("Canberra", "Australia");
countries.put("Madrid", "Spain");
System.out.println("HashMap: " + countries);
//合并 key为 Washington的映射
String returnedValue = countries.merge("Washington", "USA", (oldValue, newValue) -> oldValue + "/" + newValue);
System.out.println("Washington: " + returnedValue);
//输出更新后的HashMap
System.out.println("Updated HashMap: " + countries);
}
}
执行以上程序输出结果为:
HashMap: {Madrid=Spain, Canberra=Australia, Washington=America}Washington: America/USAUpdated HashMap: {Madrid=Spain, Canberra=Australia, Washington=America/USA},
在以上实例中,我们创建了一个名为 contries 的 HashMap。
注意表达式:
countries.merge("Washington", "USA", (oldValue, newValue) -> oldValue + "/" + newValue)
在这里,我们使用了 lambda表达式 (oldValue, newValue) -> oldValue + "/" + newValue) 作为重映射函数。
因为键 washington 已经存在于 countries,旧值被重映射函数返回的值替换。因此,Washington 的映射包含了 America/USA。