对 map 集合使用 " + " 操作符 , 操作符两侧都是 map 集合 , 调用的是 map 集合的 plus 方法 , plus 函数有
个参数 :
该 plus 方法的作用是 , 将 Map<K, V> left 参数 和 Map<K, V> right 参数 的键值对 都放在一个新的 map 集合中 , 注意是 新的 map 集合 ;
map 集合的 plus 函数原型 :
/**
* 返回新的 <code>Map</code>集合 包含了所有的 从 <code>left</code> 到 <code>right</code> 的entry 键值对,
* 优先于 <code>right</code>. 两个 map 中出现的任何关键点都将与来自 <code>right</code>
* 操作数. 如果 <code>left</code> map 是TreeMap、LinkedHashMap、Hashtable或属性之一,
* 返回的映射将保留该类型,否则将返回 HashMap。
* <p>
* 大致相当于 <code>Map m = new HashMap(); m.putAll(left); m.putAll(right); return m;</code>
* 但是需要一些额外的逻辑来为上述常见情况保留<code>left</code>映射类型。
* <pre class="groovyTestCase">
* assert [a:10, b:20] + [a:5, c:7] == [a:5, b:20, c:7]
* </pre>
*
* @param left 原始 map 集合
* @param right 要累加的 map 集合
* @return 返回一个新的集合 , 既包含 left 集合中的键值对 , 又包含 right 集合中的键值对
* @since 1.5.0
*/
public static <K, V> Map<K, V> plus(Map<K, V> left, Map<K, V> right) {
Map<K, V> map = cloneSimilarMap(left);
map.putAll(right);
return map;
}
代码示例 :
class Test {
static void main(args) {
// 创建键值对
// 键 Key 可以不使用引号 , 可以使用单引号 '' , 也可以使用双引号 ""
def map = [J:"Java", "K":"Kotlin", 'G':"Groovy"]
// " + " 操作符重载
def map2 = map + [S:"String"]
// 打印结果 [J:Java, K:Kotlin, G:Groovy]
println map
// 打印结果 [J:Java, K:Kotlin, G:Groovy, S:String]
println map2
}
}
执行结果 :
[J:Java, K:Kotlin, G:Groovy]
[J:Java, K:Kotlin, G:Groovy, S:String]