Scalaコレクション-マップ

Scalaマップは、キーと値のペアのコレクションです。キーに基づいて任意の値を取得できます。キーはマップ内で一意ですが、値は一意である必要はありません。マップはハッシュテーブルとも呼ばれます。マップには2種類あります。immutable そしてその mutable。可変オブジェクトと不変オブジェクトの違いは、オブジェクトが不変の場合、オブジェクト自体を変更できないことです。

デフォルトでは、Scalaは不変のマップを使用します。可変マップを使用する場合は、インポートする必要がありますscala.collection.mutable.Map明示的にクラス。可変マップと不変マップの両方を同じように使用する場合は、引き続き不変マップを次のように参照できます。Map ただし、可変セットは次のように参照できます。 mutable.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")

空のマップを定義する際、システムは具体的な型を変数に割り当てる必要があるため、型の注釈が必要です。キーと値のペアをマップに追加する場合は、次のように演算子+を使用できます。

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

MAPの基本操作

マップ上のすべての操作は、次の3つの方法で表すことができます。

シニア番号 方法と説明
1

keys

このメソッドは、マップ内の各キーを含むイテラブルを返します。

2

values

このメソッドは、マップ内の各値を含むiterableを返します。

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。このプログラムをコンパイルして実行するには、次のコマンドを使用します。

コマンド

\>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.++() 2つ以上のマップを連結する方法ですが、マップを追加すると、重複するキーが削除されます。

次のサンプルプログラムを試して、2つのマップを連結します。

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)

マップからキーと値を印刷する

「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。このプログラムをコンパイルして実行するには、次のコマンドを使用します。

コマンド

\>scalac Demo.scala
\>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。このプログラムをコンパイルして実行するには、次のコマンドを使用します。

コマンド

\>scalac Demo.scala
\>scala Demo

出力

Red key exists with value :#FF0000
Maroon key does not exist