Scala對映(Map
)是一組鍵/值對的物件。 任何值都可以根據鍵來進行檢索。鍵在對映中是唯一的,但值不一定是唯一的。對映也稱為雜湊表。對映有兩種,不可變的和可變的。可變物件和不可變物件之間的區別在於,當物件不可變時,物件本身無法更改。
預設情況下,Scala使用不可變對映(Map
)。如果要使用可變集合(Map
),則需要明確匯入scala.collection.mutable.Map
類。如果想同時使用可變的和不可變對映(Map
),那麼可以繼續參照不可變對映(Map
),但是可以將mutable
集合參照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
)的所有操作都可以用以下三種方法來表示:
序號 | 方法 | 描述 |
---|---|---|
1 | keys | 此方法返回包含對映中每個鍵的疊代。 |
2 | values | 此方法返回一個包含對映中每個值的疊代。 |
3 | isEmpty | 如果列表為空,則此方法返回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中,使用以下命令編譯和執行此程式。
D:\>scalac Demo.scala
D:\>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.++()
方法連線兩個或多個對映,但在新增對映時,它將刪除重複的鍵。
嘗試以下範例程式連線兩個對映。
以下是連線兩個對映的例子 -
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中,使用以下命令編譯和執行此程式。
D:\>scalac Demo.scala
D:\>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)
可以使用foreach
迴圈疊代對映的鍵和值。在這裡,使用與疊代器相關聯的方法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中,使用以下命令編譯和執行此程式。
D:\>scalac Demo.scala
D:\>scala Demo
Key = red Value = #FF0000
Key = azure Value = #F0FFFF
Key = peru Value = #CD853F
可以使用Map.contains
方法來測試對映中給定的鍵是否存在。嘗試以下範例程式進行鍵檢查。
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中,使用以下命令編譯和執行此程式。
D:\>scalac Demo.scala
D:\>scala Demo
Red key exists with value :#FF0000
Maroon key does not exist
有關可用方法的完整列表,請檢視Scala的官方文件。