【Groovy】map 集合 ( map 集合操作符重载 | + 操作符重载 | 代码示例 )
【摘要】
文章目录
一、map 集合 " + " 操作符重载二、代码示例
一、map 集合 " + " 操作符重载
对 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]
文章来源: hanshuliang.blog.csdn.net,作者:韩曙亮,版权归原作者所有,如需转载,请联系作者。
原文链接:hanshuliang.blog.csdn.net/article/details/122182911
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
作者其他文章
评论(0)