【Groovy】map 集合 ( map 集合操作符重载 | + 操作符重载 | 代码示例 )
生活随笔
收集整理的這篇文章主要介紹了
【Groovy】map 集合 ( map 集合操作符重载 | + 操作符重载 | 代码示例 )
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
文章目錄
- 一、map 集合 " + " 操作符重載
- 二、代碼示例
一、map 集合 " + " 操作符重載
對(duì) map 集合使用 " + " 操作符 , 操作符兩側(cè)都是 map 集合 , 調(diào)用的是 map 集合的 plus 方法 , plus 函數(shù)有 222 個(gè)參數(shù) :
- 第一個(gè)參數(shù) , Map<K, V> left 參數(shù)是 " + " 操作符 左側(cè)的 map 集合 ;
- 第二個(gè)參數(shù) , Map<K, V> right 參數(shù)是 " + " 操作符 右側(cè)的 map 集合 ;
該 plus 方法的作用是 , 將 Map<K, V> left 參數(shù) 和 Map<K, V> right 參數(shù) 的鍵值對(duì) 都放在一個(gè)新的 map 集合中 , 注意是 新的 map 集合 ;
map 集合的 plus 函數(shù)原型 :
/*** 返回新的 <code>Map</code>集合 包含了所有的 從 <code>left</code> 到 <code>right</code> 的entry 鍵值對(duì),* 優(yōu)先于 <code>right</code>. 兩個(gè) map 中出現(xiàn)的任何關(guān)鍵點(diǎn)都將與來自 <code>right</code>* 操作數(shù). 如果 <code>left</code> map 是TreeMap、LinkedHashMap、Hashtable或?qū)傩灾?#xff0c;* 返回的映射將保留該類型,否則將返回 HashMap。* <p>* 大致相當(dāng)于 <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 返回一個(gè)新的集合 , 既包含 left 集合中的鍵值對(duì) , 又包含 right 集合中的鍵值對(duì)* @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) {// 創(chuàng)建鍵值對(duì)// 鍵 Key 可以不使用引號(hào) , 可以使用單引號(hào) '' , 也可以使用雙引號(hào) ""def map = [J:"Java", "K":"Kotlin", 'G':"Groovy"]// " + " 操作符重載def map2 = map + [S:"String"]// 打印結(jié)果 [J:Java, K:Kotlin, G:Groovy]println map// 打印結(jié)果 [J:Java, K:Kotlin, G:Groovy, S:String]println map2} }執(zhí)行結(jié)果 :
[J:Java, K:Kotlin, G:Groovy] [J:Java, K:Kotlin, G:Groovy, S:String]總結(jié)
以上是生活随笔為你收集整理的【Groovy】map 集合 ( map 集合操作符重载 | + 操作符重载 | 代码示例 )的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【Groovy】map 集合 ( map
- 下一篇: 【Groovy】map 集合 ( map