Scala 簡明速學(xué)04 集合-Map
Map
Scala中Map提供鍵值對集合照弥。
Map的初始化
Scala中的Map分為可變Map與不可變Map邀泉。不可變Map初始化后不可更改其元素炫彩。
object MapInitTest {
def main(args: Array[String]): Unit = {
//默認(rèn)創(chuàng)建不可變map
val lakers = Map("Lebron" -> 23, "Rondo" -> 9, "Ball" -> 2)
println(lakers)
println(lakers("Rondo")) //訪問map
//不可變Map矩欠,初始化后不可修改倦踢,不可以添加元素炕倘,也不可以修改元素
//lakers("Kuzma") = 0//添加操作
//lakers("Rando") = -1//修改操作
//創(chuàng)建可變的Map
val lakers2 = scala.collection.mutable.Map("Lebron" -> 23, "Rondo" -> 9)
lakers2("Kuzma") = 0
println(lakers2)
//使用元組語法初始化Map
val lakers3 = Map(("Zubac", 40), ("Ingram", 14), ("McGee", 7))
println(lakers3)
//創(chuàng)建一個元素為空的Map
var lakers4 = new mutable.HashMap[String, Int]()
lakers4.put("Chandler", 5)
lakers4.+=("Beasley" -> 11)
println(lakers4)
}
}
Map的基本操作
對于可變Map,進(jìn)行增刪改查操作。
object MapBasicOpt {
def main(args: Array[String]): Unit = {
val lakers = scala.collection.mutable.Map("Lebron" -> 23, "Rondo" -> 9)
try {
//獲取元素,如果獲取的元素不在集合中瘤运,會拋出異常
val player = lakers("Tatum")
println(player)
} catch {
case e: NoSuchElementException => e.printStackTrace()
}
//檢查元素是否存在
println(lakers.contains("Lebron"))
//給定默認(rèn)值獲取元素
println(lakers.getOrElse("Tatum", -1))
//添加元素
lakers("Stephenson") = 6
//添加多個元素
lakers += ("Hart" -> 3, "Pope" -> 1)
//更新元素
lakers("Rondo") = -1
//刪除元素
lakers.remove("Tatum")
}
}
對于不可變Map,增刪改查的操作不會改變原有Map,而是返回一個新的Map窍霞。
object MapBasicOpt2 {
def main(args: Array[String]): Unit = {
val lakers = Map("Lebron" -> 23)
//增加元素,返回新集合
val lakers2 = lakers + ("Rondo" -> 9, "Ball" -> 2)
//刪除元素,返回新集合
val lakers3 = lakers2 - "Ball" - "Rondo"
//更新元素尽超,返回新集合
val lakers4 = lakers3.updated("Lebron", 6)
}
}
Map的遍歷
可以使用增強for循環(huán),foreach方法對Map進(jìn)行遍歷官撼。
object MapIterate {
def main(args: Array[String]): Unit = {
val lakers = Map("Lebron" -> 23, "Ball" -> 2, "Kuzma" -> 0)
//增強for循環(huán),遍歷key,value
for ((k, v) <- lakers) println(k, v)
//增強for循環(huán),遍歷value
for ((_, v) <- lakers) println(v)
//增強for循環(huán),遍歷key
for ((k, _) <- lakers) println(k)
//只遍歷Map的key
for (k <- lakers.keySet) println(k)
//只遍歷Map的value
for (v <- lakers.values) println(v)
//使用foreach遍歷Map
lakers.foreach(e => println(e._1, e._2))
//生成新Map,并反轉(zhuǎn)Key與Value,使用增強for循環(huán)
val lakers2 = for ((k, v) <- lakers) yield (v, k)
//生成新Map,并反轉(zhuǎn)Key與Value,使用foreach
val lakers3 = lakers.map(e => (e._2, e._1))
}
}