Scala 集合 - Map



Scala 的 Map 是一個鍵值對的集合。任何值都可以根據其鍵檢索。Map 中的鍵是唯一的,但值不必唯一。Map 也稱為雜湊表。Map 有兩種型別:**不可變**和**可變**。不可變物件和可變物件的區別在於,當物件是不可變時,物件本身不能被更改。

預設情況下,Scala 使用不可變 Map。如果要使用可變 Map,則必須顯式匯入 **scala.collection.mutable.Map** 類。如果要在同一個程式中使用可變和不可變 Map,則可以繼續將不可變 Map 稱為 **Map**,但可變 Map 可以稱為 **mutable.Map**。

以下是宣告不可變 Map 的示例語句:

// Empty hash table whose keys are strings and values are integers:
var A:Map[Char,Int] = Map()

// A map with keys and values.
val colors = Map("red" -> "#FF0000", "azure" -> "#F0FFFF")

定義空 Map 時,型別註釋是必要的,因為系統需要為變數分配具體的型別。如果要向 Map 新增鍵值對,可以使用 + 運算子,如下所示。

A + = ('I' -> 1)
A + = ('J' -> 5)
A + = ('K' -> 10)
A + = ('L' -> 100)

Map 的基本操作

Map 的所有操作都可以用以下三種方法來表示。

序號 方法和描述
1

keys

此方法返回一個包含 Map 中每個鍵的可迭代物件。

2

values

此方法返回一個包含 Map 中每個值的可迭代物件。

3

isEmpty

如果 Map 為空,此方法返回 true,否則返回 false。

嘗試以下示例程式,該程式演示了 Map 方法的使用。

示例

object Demo {
   def main(args: Array[String]) {
      val colors = Map(
         "red" -> "#FF0000", "azure" -> "#F0FFFF", "peru" -> "#CD853F"
      )
      val nums: Map[Int, Int] = Map()
      println( "Keys in colors : " + colors.keys )
      println( "Values in colors : " + colors.values )
      println( "Check if colors is empty : " + colors.isEmpty )
      println( "Check if nums is empty : " + nums.isEmpty )
   }
}

將上述程式儲存為 **Demo.scala**。使用以下命令編譯並執行此程式。

命令

\>scalac Demo.scala
\>scala Demo

輸出

Keys in colors : Set(red, azure, peru)
Values in colors : MapLike(#FF0000, #F0FFFF, #CD853F)
Check if colors is empty : false
Check if nums is empty : true

連線 Map

您可以使用 **++** 運算子或 **Map.++()** 方法來連線兩個或多個 Map,但在新增 Map 時,它會刪除重複的鍵。

嘗試以下示例程式來連線兩個 Map。

示例

object Demo {
   def main(args: Array[String]) {
      val colors1 = Map(
         "red" -> "#FF0000", "azure" -> "#F0FFFF", "peru" -> "#CD853F"
      )
      val colors2 = Map(
         "blue" -> "#0033FF", "yellow" -> "#FFFF00", "red" -> "#FF0000"
      )
      // use two or more Maps with ++ as operator
      var colors = colors1 ++ colors2
      println( "colors1 ++ colors2 : " + colors )
      // use two maps with ++ as method
      colors = colors1.++(colors2)
      println( "colors1.++(colors2)) : " + colors )
   }
}

將上述程式儲存為 **Demo.scala**。使用以下命令編譯並執行此程式。

命令

\>scalac Demo.scala
\>scala Demo

輸出

colors1 ++ colors2 : Map(blue -> #0033FF, azure -> #F0FFFF, 
   peru -> #CD853F, yellow -> #FFFF00, red -> #FF0000)

colors1.++(colors2)) : Map(blue -> #0033FF, azure -> #F0FFFF, 
   peru -> #CD853F, yellow -> #FFFF00, red -> #FF0000)

從 Map 中列印鍵和值

您可以使用 "foreach" 迴圈遍歷 Map 的鍵和值。在這裡,我們使用與迭代器關聯的 foreach 方法來遍歷鍵。以下是一個示例程式。

示例

object Demo {
   def main(args: Array[String]) {
      val colors = Map("red" -> "#FF0000", "azure" -> "#F0FFFF","peru" -> "#CD853F")

      colors.keys.foreach{
         i =>  
         print( "Key = " + i )
         println(" Value = " + colors(i) )
      }
   }
}

將上述程式儲存為 **Demo.scala**。使用以下命令編譯並執行此程式。

命令

\>scalac Demo.scala
\>scala Demo

輸出

Key = red Value = #FF0000
Key = azure Value = #F0FFFF
Key = peru Value = #CD853F

檢查 Map 中是否存在鍵

您可以使用 **Map.contains** 方法來測試給定的鍵是否存在於 Map 中。嘗試以下示例程式進行鍵檢查。

示例

object Demo {
   def main(args: Array[String]) {
      val colors = Map(
         "red" -> "#FF0000", "azure" -> "#F0FFFF", "peru" -> "#CD853F"
      )
      if( colors.contains( "red" )) {
         println("Red key exists with value :"  + colors("red"))
      } else {
         println("Red key does not exist")
      }
      if( colors.contains( "maroon" )) {
         println("Maroon key exists with value :"  + colors("maroon"))
      } else {
         println("Maroon key does not exist")
      }
   }
}

將上述程式儲存為 **Demo.scala**。使用以下命令編譯並執行此程式。

命令

\>scalac Demo.scala
\>scala Demo

輸出

Red key exists with value :#FF0000
Maroon key does not exist
廣告
© . All rights reserved.