Scala 컬렉션-지도

스칼라 맵은 키 / 값 쌍의 모음입니다. 키를 기반으로 모든 값을 검색 할 수 있습니다. 키는 맵에서 고유하지만 값이 고유 할 필요는 없습니다. 맵은 해시 테이블이라고도합니다. 두 종류의지도가 있습니다.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의 기본 작업

지도에 대한 모든 작업은 다음 세 가지 방법으로 표현할 수 있습니다.

Sr. 아니요 방법 및 설명
1

keys

이 메소드는 맵의 각 키를 포함하는 이터 러블을 반환합니다.

2

values

이 메소드는지도의 각 값을 포함하는 이터 러블을 반환합니다.

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.++() 두 개 이상의 맵을 연결하는 방법이지만 맵을 추가하는 동안 중복 키가 제거됩니다.

다음 예제 프로그램을 사용하여 두 개의 맵을 연결하십시오.

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