文章目录
- 一、map 集合 " + " 操作符重载
- 二、代码示例
一、map 集合 " + " 操作符重载
对 map 集合使用 " + " 操作符 , 操作符两侧都是 map 集合 , 调用的是 map 集合的 plus 方法 , plus 函数有 2 2 2 个参数 :
- 第一个参数 , Map<K, V> left 参数是 " + " 操作符 左侧的 map 集合 ;
- 第二个参数 , Map<K, V> right 参数是 " + " 操作符 右侧的 map 集合 ;
该 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]










![面试06,[长亮科技]()(offer)、[荔枝]()FM(在确定部门和薪资)、[涂鸦智能]()(第一轮电话面半小时,待后续)、华资软件(HR面)、[广州速游]()(已挂)。至于公司怎么样不加以言论。](https://img-blog.csdnimg.cn/img_convert/0a8f4edbf8a2587426f02790e8085e9c.png)








