Map(映射)是一種可迭代的鍵值對(key/value)結構。
所有的值都可以通過鍵來獲取。
Map 中的鍵都是唯一的。
Map 也叫哈希表(Hash tables)。
Map 有兩種類型,可變與不可變,區別在於可變對象可以修改它,而不可變對象不可以。
默認情況下 Scala 使用不可變 Map。如果你需要使用可變集合,你需要顯式的引入 import scala.collection.mutable.Map 類
在Scala中你可以同時使用可變與不可變 Map,不可變的直接使用 Map,可變的使用 mutable.Map.以下實例演示了不可變 Map 的應用:
package test
/**
* map的操作;
*/
object MapDemo {
def main(args: Array[String]): Unit = {
var map = Map[String,String]("name" -> "jason","age" -> "500","test_100" -> "test_100","test_101" -> "test_101") //引用可變,支持讀寫操作;
map += ("city" -> "北京") //新增
println(map) //打印結果爲:Map(city -> 北京, name -> jason, test_100 -> test_100, test_101 -> test_101, age -> 500);
val map2 = Map[String,String]("sex" -> "男","brand" -> "apple") //引用不可變,只能第一次寫入值,之後只能讀取;
//map2 += ("test" -> "報錯嗎") //此時不能加,直接報錯;
val map3 = scala.collection.mutable.Map[String,String]() //引用不可變,支持讀寫操作;
map3 += ("test" -> "能添加嗎") //添加單個元素;
map3 += ("test" -> "改變了") //更新;
map3 += ("success" -> "添加成功了嗎","anthor" -> "另外一個") //添加多個元素;
println(map3) //打印結果爲:Map(success -> 添加成功了嗎, anthor -> 另外一個, test -> 能添加嗎);
println(map3.keys) //返回所有的key;
println(map3.values)//返回所有的value;
println(map3.isEmpty) //當map爲空時,返回true;
var combine_map = map ++ map2 //合併兩個map;
println(combine_map) //打印結果爲:Map(city -> 北京, name -> jason, test_100 -> test_100, test_101 -> test_101, age -> 500, brand -> apple, sex -> 男);
combine_map -= ("city","name") //刪除指定的key;
println(combine_map) //打印結果爲:Map(test_100 -> test_100, test_101 -> test_101, age -> 500, brand -> apple, sex -> 男)
println(combine_map.get("age").get) //返回指定key的值;
println(combine_map.init) //返回所有元素,除了最後一個;
println(combine_map.last) //返回最後一個元素;
println(combine_map.max) //查找最大元素;
println(combine_map.min) //查找最小元素;
println(combine_map.mkString("")) //集合所有元素作爲字符串顯示;
//println(combine_map.product) //返回集合中數字元素的積;注意得是num型;
println(combine_map.size) //返回map的大小;
println(combine_map.toArray) //集合轉數組;
println(combine_map.toBuffer) //返回緩衝區,包含了Map的所有元素;
println(combine_map.toList) //返回List,包含了Map的所有元素;
combine_map.get("test_101").getOrElse("不存在") //根據key取value值,如果不存在返回後面的值;
val keySet = combine_map.keys
val key_iter = keySet.iterator //遍歷,迭代map;
while (key_iter.hasNext){
val key = key_iter.next
println(key + ":" + combine_map.get(key).get)
}
println(combine_map.apply("brand")) //返回指定鍵的值,如果不存在返回 Map 的默認方法;
println(combine_map.contains("test_key")) //如果map中存在指定 key,返回 true,否則返回 false;
val age_count = combine_map.count(x=>{ //計算滿足指定條件的集合元素數量;
x._1.equals("age")
})
println(age_count) //打印結果爲1;
val drop_map = combine_map.drop(1) //返回丟棄最後n個元素新集合;
println(drop_map) //打印結果爲:Map(brand -> apple, sex -> 男);
println(combine_map.empty) //返回相同類型的空map;
println(map.equals(map2)) //如果兩個 Map 相等(key/value 均相等),返回true,否則返回false;
println(combine_map.exists(x => { //判斷集合中指定條件的元素是否存在;
x._2.equals("男")
}))
println(combine_map.filter(x=>{ //返回滿足指定條件的所有集合; 結果爲:Map(brand -> apple);
x._1.length > 4
}))
println(combine_map.filterKeys(x=>{ //返回符合指定條件的不可變 Map;
x.equals("test_100")
}))
println(combine_map.find(x=>{ //查找集合中滿足指定條件的第一個元素;
x._1.equals(x._2)
}))
combine_map.foreach(x=>{ //循環map裏的所有元素;
println(x +"------------")
})
}
}
轉自https://blog.csdn.net/xianpanjia4616/article/details/80947616