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