Scala與Java差異(五)之Map與Tuple

茅坤寶駿氹發表於2020-11-22

一、 建立Map

(1)建立Map

// 建立一個不可變的Map
val ages = Map("Leo" -> 30, "Jen" -> 25, "Jack" -> 23)
ages("Leo") = 31
// 建立一個可變的Map
val ages = scala.collection.mutable.Map("Leo" -> 30, "Jen" -> 25, "Jack" -> 23)
ages("Leo") = 31
// 使用另外一種方式定義Map元素
val ages = Map(("Leo", 30), ("Jen", 25), ("Jack", 23))
// 建立一個空的HashMap
val ages = new scala.collection.mutable.HashMap[String, Int]

(2)訪問Map的元素

// 獲取指定key對應的value,如果key不存在,會報錯
val leoAge = ages("Leo")
val leoAge = ages("leo")

// 使用contains函式檢查key是否存在
val leoAge = if (ages.contains("leo")) ages("leo") else 0

// getOrElse函式
val leoAge = ages.getOrElse("leo", 0)

(3)修改Map的元素

// 更新Map的元素
ages("Leo") = 31
// 增加多個元素
ages += ("Mike" -> 35, "Tom" -> 40)
// 移除元素
ages -= "Mike"
// 更新不可變的map
val ages2 = ages + ("Mike" -> 36, "Tom" -> 40)
// 移除不可變map的元素
val ages3 = ages - "Tom"

(4)遍歷Map

// 遍歷map的entrySet
for ((key, value) <- ages) println(key + " " + value)
// 遍歷map的key
for (key <- ages.keySet) println(key)
// 遍歷map的value
for (value <- ages.values) println(value)
// 生成新map,反轉key和value
for ((key, value) <- ages) yield (value, key)

(5) SortedMap和LinkedHashMap

// SortedMap可以自動對Map的key的排序
val ages = scala.collection.immutable.SortedMap("leo" -> 30, "alice" -> 15, "jen" -> 25)

// LinkedHashMap可以記住插入entry的順序
val ages = new scala.collection.mutable.LinkedHashMap[String, Int]
ages("leo") = 30
ages("alice") = 15
ages("jen") = 25

 

二、Map的元素型別—Tuple

// 簡單Tuple
val t = ("leo", 30)

// 訪問Tuple
t._1

// zip操作
val names = Array("leo", "jack", "mike")
val ages = Array(30, 24, 26)
val nameAges = names.zip(ages)
for ((name, age) <- nameAges) println(name + ": " + age)

 

相關文章