Scala之Map

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

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章