Map.merge()
方法是 Java 中用于将指定的键和值合并到 Map 中的方法。如果 Map 中已经存在指定的键,则将给定的值与现有值合并,并且根据提供的合并函数来确定最终的值。如果 Map 中不存在指定的键,则简单地将指定的键值对插入 Map 中。
下面是 Map.merge()
方法的语法:
default V merge(K key, V value, BiFunction<? super V,? super V,? extends V> remappingFunction)
key
:要合并的键。value
:要与键关联的值。remappingFunction
:在键已经存在时应用的合并函数。
合并函数接受两个参数:旧值和新值,并返回一个值,表示要将两个值合并后得到的结果。如果键不存在,则新值直接插入到 Map 中。
下面是一个简单的示例,演示了如何使用 Map.merge()
方法:
import java.util.HashMap;
import java.util.Map;
public class MapMergeExample {
public static void main(String[] args) {
Map<String, Integer> map = new HashMap<>();
// 向 map 中插入一些初始数据
map.put("apple", 1);
map.put("banana", 2);
map.put("cherry", 3);
// 将新的值与现有的键合并
map.merge("apple", 10, (oldValue, newValue) -> oldValue + newValue);
System.out.println("After merging: " + map);
// 插入新的键值对
map.merge("grape", 5, (oldValue, newValue) -> oldValue + newValue);
System.out.println("After merging: " + map);
}
}
在这个示例中,我们首先向 Map 中插入了一些初始数据,然后使用 merge()
方法将新的值与现有的键合并。如果键已经存在,我们使用提供的合并函数将旧值和新值相加。最后,我们插入了一个新的键值对,因为该键在 Map 中不存在,所以直接插入。
运行上述代码,输出将是:
After merging: {apple=11, cherry=3, banana=2}
After merging: {grape=5, apple=11, cherry=3, banana=2}
以上示例演示了 merge()
方法的基本用法。接下来,让我们通过更多的示例来进一步理解它的功能。
示例一:合并列表元素计数
假设我们有一个字符串列表,我们想要计算每个字符在列表中出现的次数,并将结果存储在一个 Map 中。
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class CharacterCountExample {
public static void main(String[] args) {
List<String> list = List.of("apple", "banana", "cherry");
Map<Character, Integer> charCountMap = new HashMap<>();
for (String str : list) {
for (char c : str.toCharArray()) {
charCountMap.merge(c, 1, Integer::sum);
}
}
System.out.println("Character count: " + charCountMap);
}
}
在这个示例中,我们遍历字符串列表,并将每个字符串拆分为字符数组。然后,我们使用 merge()
方法将每个字符的计数值合并到 Map 中。如果字符已经存在于 Map 中,则将计数值增加 1;否则,将新的字符插入到 Map 中,并初始化计数值为 1。
示例二:合并相同键的值
假设我们有两个 Map,我们想将它们合并成一个 Map,如果键相同,则将相应的值相加。
import java.util.HashMap;
import java.util.Map;
public class MergeMapsExample {
public static void main(String[] args) {
Map<String, Integer> map1 = new HashMap<>();
map1.put("apple", 5);
map1.put("banana", 3);
Map<String, Integer> map2 = new HashMap<>();
map2.put("apple", 2);
map2.put("cherry", 4);
Map<String, Integer> mergedMap = new HashMap<>(map1);
map2.forEach((key, value) ->
mergedMap.merge(key, value, Integer::sum));
System.out.println("Merged map: " + mergedMap);
}
}
在这个示例中,我们首先将 map1
中的所有键值对复制到 mergedMap
中。然后,我们遍历 map2
,对于每个键值对,如果键已经存在于 mergedMap
中,则将对应的值相加;否则,将新的键值对插入到 mergedMap
中。
通过这些示例,你应该对 Map.merge()
方法有了更深入的理解。它是一个非常有用的方法,可以简化许多与 Map 相关的操作。