 
- Scala - Home
- Scala - Overview
- Scala - Features
- Scala - Environment Setup
- Scala - Build Tool (SBT)
- Scala - REPL
- Scala - Dot & Dotty
- Scala - Basic Syntax
- Scala - Hello World Program
- Scala - Identifiers
- Scala - Keywords
- Scala - Comments
- Scala - Code Blocks
- Scala - Semicolon
- Scala - Constructs
- Scala - Expressions
- Scala - Input and Output
- Scala - Optional Braces
- Scala - Underscore (_)
- Data Types and Variables
- Scala - Data Types
- Scala - Type Bounds
- Scala - Context Bound
- Scala - Variances
- Scala - Type Hierarchy
- Scala - Variables
- Scala - Variable Scopes
- Scala - Literals
- Scala - Numeric Types
- Scala - Boolean Types
- Scala - Char Type
- Scala - Unit Types
- Scala - Strings
- Scala - Arrays
- Scala - Null Type
- Scala - Nothing
- Scala - Any Type
- Scala - AnyRef Type
- Scala - Unified Types
- Scala - Dates and Times
- Scala - Ranges
- Scala - Multidimensional Arrays
- Scala - WrappedArray
- Scala - StringBuilder
- Scala - String Interpolation
- Scala - StringContext
- Scala - Type Casting
- Scala var vs val
- Scala Operators
- Scala - Operators
- Scala - Rules for Operators
- Scala - Arithmetic Operators
- Scala - Relational Operators
- Scala - Logical Operators
- Scala - Bitwise Operators
- Scala - Assignment Operators
- Scala - Operators Precedence
- Scala - Symbolic Operators
- Scala - Range Operator
- Scala - String Concatenation Operator
- Scala Conditional Statements
- Scala - IF ELSE
- Scala - IF-ELSE-IF-ELSE Statement
- Scala - Nested IF-ELSE Statement
- Scala Loop Statements
- Scala - Loop Statements
- Scala - while Loop
- Scala - do-while Loop
- Scala - Nested Loops
- Scala - for Loop
- Scala - break Statement
- Scala - yield Keyword
- Scala Classes & Objects
- Scala - Classes & Objects
- Scala - Constructors
- Scala - Auxiliary Constructor
- Scala - Primary Constructor
- Scala - This Keyword
- Scala - Nested Classes
- Scala - Getters and Setters
- Scala - Object Private Fields
- Scala - Singleton Object
- Scala - Companion Objects
- Scala - Creating Executable Programs
- Scala - Stateful Object
- Scala - Enumerations
- Scala - Polymorphism
- Scala - Access Modifiers
- Scala - Apply Method
- Scala - Update Methods
- Scala - UnapplySeq Method
- Scala - Inheritance
- Scala - Extending a Class
- Scala - Method Overloading
- Scala - Method Overriding
- Scala - Generic Classes
- Scala - Generic Functions
- Scala - Superclass Construction
- Scala Methods & Functions
- Scala - Methods
- Scala - Functions
- Scala - Methods vs Functions
- Scala - Main Methods
- Scala - Functions Call-by-Name
- Scala - Functions with Named Arguments
- Scala - Function with Variable Arguments
- Scala - Recursion Functions
- Scala - Default Parameter Values
- Scala - Functions without Parameters
- Scala - Implicit Parameters
- Scala - Higher-Order Functions
- Scala - Nested Functions
- Scala - Extension Methods
- Scala - Anonymous Functions
- Partially Applied Functions
- Scala - Lazy Val
- Scala - Pure Function
- Scala - Currying Functions
- Scala - Control Abstractions
- Scala - Corecursion
- Scala - Unfold
- Scala - Tail Recursion
- Scala - Infinite Sequences
- Scala - Dynamic Invocation
- Scala - Lambda Expressions
- Scala - Polymorphic Functions
- Scala Collections
- Scala - Collections
- Mutable and Immutable Collections
- Scala - Lists
- Scala - Sets
- Scala - Maps
- Scala - TreeMap
- Scala - SortedMap
- Scala - Tuples
- Scala - Iterators
- Scala - Options
- Scala - NumericRange
- Scala - Infinite Streams
- Scala - Parallel Collections
- Scala Advanced Types
- Scala - Union Types
- Scala - Intersection Types
- Scala - Type Aliases
- Scala - Structural Types
- Scala - Match Expression
- Scala - Singleton Type Operator
- Scala - Abstract Types
- Scala - Dependent Types
- Scala - Abstract Type Bounds
- Scala - Higher-Kinded Types
- Scala - Opaque Type Alias
- Scala - Path-Dependent Types
- Scala - Type Lambdas
- Scala - Type Inference
- Scala - Algebraic Data Types
- Scala Pattern Matching
- Scala - Pattern Matching
- Scala - Guards
- Scala - Variables in Patterns
- Scala - Type Patterns
- Scala - The Matchable Trait
- Scala - Matching Arrays
- Scala - Matching Lists
- Scala - Matching Tuples
- Scala - Exception Handling
- Scala - Extractors
- Scala - Pattern Bindings
- Scala - Regular Expressions
- Scala - Case Classes
- Scala - Partial Functions
- Scala - Packaging and Imports
- Scala - Implicit Imports
- Scala - Export Clauses
- Scala - Nested Packages
- Scala - Chained Packages
- Scala - Package Objects
- Scala Files I/O
- Scala - Files I/O
- Scala - Writing Files
- Scala - Listing Files
- Scala - Deleting Directories
- Scala - Check File Exists
- Scala Advanced Concepts
- Scala - Closures
- Scala - Futures
- Scala - Promises
- Scala - Traits
- Scala - Trait Mixins
- Scala - Layered Traits
- Scala - Trait Linearization
- Scala - Sealed Traits
- Scala - Transparent Traits
- Scala - Process Management
- Scala - Scaladoc
- Scala - Literal Type Arithmetic
- Scala - Inline keyword
- Scala - Def, Var & Val
- Scala - Dropped Features
- Scala Unit Testing
- Scala - Unit Testing
- Scala - uTest
- Scala - MUnit
- Scala - ScalaTest Runner
- Scala - ScalaMock
- Scala - JUnit
- Scala - Mocking
- Scala - BDD Testing
Scala - Maps
Scala map is a collection of key/value pairs. Any value can be retrieved based on its key. Keys are unique in the Map, but values need not be unique. Maps are also called Hash tables. There are two kinds of Maps, the immutable and the mutable. The difference between mutable and immutable objects is that when an object is immutable, the object itself can't be changed.
By default, Scala uses the immutable Map. If you want to use the mutable Map, you'll have to import scala.collection.mutable.Map class explicitly. If you want to use both mutable and immutable Maps in the same, then you can continue to refer to the immutable Map as Map but you can refer to the mutable set as mutable.Map.
The Following is the example statements to declare immutable Maps −
// 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")
While defining empty map, the type annotation is necessary as the system needs to assign a concrete type to variable. If we want to add a key-value pair to a Map, we can use the operator + as follows.
A + = ('I' -> 1)
A + = ('J' -> 5)
A + = ('K' -> 10)
A + = ('L' -> 100)
Basic Operations on MAP
All operations on maps can be expressed in terms of the following three methods.
| Sr.No | Methods & Description | 
|---|---|
| 1 | keys This method returns an iterable containing each key in the map. | 
| 2 | values This method returns an iterable containing each value in the map. | 
| 3 | isEmpty This method returns true if the map is empty otherwise false. | 
Try the following example program showing usage of the Map methods.
Example
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 )
   }
}
Save the above program in Demo.scala. The following commands are used to compile and execute this program.
Command
\>scalac Demo.scala \>scala Demo
Output
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
Concatenating Maps
You can use either ++ operator or Map.++() method to concatenate two or more Maps, but while adding Maps it will remove duplicate keys.
Try the following example program to concatenate two Maps.
Example
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 )
   }
}
Save the above program in Demo.scala. The following commands are used to compile and execute this program.
Command
\>scalac Demo.scala \>scala Demo
Output
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)
Print Keys and Values from a Map
You can iterate through the keys and values of a Map using foreach loop. Here, we used method foreach associated with iterator to walk through the keys. Following is the example program.
Example
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) )}
   }
}
Save the above program in Demo.scala. The following commands are used to compile and execute this program.
Command
\>scalac Demo.scala \>scala Demo
Output
Key = red Value = #FF0000 Key = azure Value = #F0FFFF Key = peru Value = #CD853F
Check for a key in Map
You can use either Map.contains method to test if a given key exists in the map or not. Try the Following example program to key checking.
Example
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")
      }
   }
}
Save the above program in Demo.scala. The following commands are used to compile and execute this program.
Command
\>scalac Demo.scala \>scala Demo
Output
Red key exists with value :#FF0000 Maroon key does not exist
Removing Key-Value Pairs from a Map
You can remove key-value pairs from a Map using the - operator or the Map.-() method. Both methods return a new map with the specified key-value pairs removed.
Example
Try following example for removing key-value pairs from a map -
object Demo {
   def main(args: Array[String]) = {
      val colors = Map("red" -> "#FF0000", "azure" -> "#F0FFFF", "peru" -> "#CD853F")
      // remove a key-value pair using the - operator
      val updatedColors1 = colors - "red"
      println("Map without red : " + updatedColors1)
      // remove a key-value pair using the - method
      val updatedColors2 = colors.-("azure")
      println("Map without azure : " + updatedColors2)
   }
}
Save the above program in Demo.scala. Use the following commands to compile and execute this program.
Command
> scalac Demo.scala > scala Demo
Output
Map without red : Map(azure -> #F0FFFF, peru -> #CD853F) Map without azure : Map(red -> #FF0000, peru -> #CD853F)
Merging Maps
You can merge two maps using the ++ operator or the Map.++() method. Both methods combine the key-value pairs of the maps, with the values from the second map overwriting the values from the first map in case of duplicate keys.
Example
object Demo {
   def main(args: Array[String]) = {
      val map1 = Map("A" -> 1, "B" -> 2, "C" -> 3)
      val map2 = Map("B" -> 20, "D" -> 4)
      // merge two maps using the ++ operator
      val mergedMap1 = map1 ++ map2
      println("Merged map using ++ operator: " + mergedMap1)
      // merge two maps using the ++ method
      val mergedMap2 = map1.++(map2)
      println("Merged map using ++ method: " + mergedMap2)
   }
}
Save the above program in Demo.scala. Use the following commands to compile and execute this program.
Command
> scalac Demo.scala > scala Demo
Output
Merged map using ++ operator: Map(A -> 1, B -> 20, C -> 3, D -> 4) Merged map using ++ method: Map(A -> 1, B -> 20, C -> 3, D -> 4)
Filtering Maps
You can filter a map based on certain conditions using the filter method. This method returns a new map containing only the key-value pairs that satisfy the predicate function.
Example
Try following example for filtering maps -
object Demo {
   def main(args: Array[String]) = {
      val scores = Map("Alice" -> 100, "Bob" -> 95, "Charlie" -> 85, "David" -> 75)
      // filter scores where the value is greater than 90
      val highScores = scores.filter { case (_, score) => score > 90 }
      println("High scores: " + highScores)
   }
}
Save the above program in Demo.scala. Use the following commands to compile and execute this program.
Command
> scalac Demo.scala > scala Demo
Output
High scores: Map(Alice -> 100, Bob -> 95)
Transforming Maps
You can transform a map by applying a transformation function to each key-value pair using the map method. This method returns a new map with the transformed key-value pairs.
Example
object Demo {
   def main(args: Array[String]) = {
      val prices = Map("Apple" -> 2.5, "Orange" -> 1.8, "Banana" -> 1.2)
      // apply 10% discount to all prices
      val discountedPrices = prices.map { case (fruit, price) => (fruit, price * 0.9) }
      println("Discounted prices: " + discountedPrices)
   }
}
Save the above program in Demo.scala. Use the following commands to compile and execute this program.
Command
> scalac Demo.scala > scala Demo
Output
Discounted prices: Map(Apple -> 2.25, Orange -> 1.62, Banana -> 1.08)
Scala Map Methods
Following are the important methods which you can use while playing with Maps. For a complete list of methods available, please check official documentation of Scala.
| Sr.No | Methods with Description | 
|---|---|
| 1 | def ++(xs: Map[(A, B)]): Map[A, B] Returns a new map containing mappings of this map and those provided by xs. | 
| 2 | def -(elem1: A, elem2: A, elems: A*): Map[A, B] Returns a new map containing all the mappings of this map except mappings with a key equal to elem1, elem2 or any of elems. | 
| 3 | def --(xs: GTO[A]): Map[A, B] Returns a new map with all the key/value mappings of this map except mappings with a key equal to a key from the traversable object xs. | 
| 4 | def get(key: A): Option[B] Optionally returns the value associated with a key. | 
| 5 | def iterator: Iterator[(A, B)] Creates a new iterator over all key/value pairs of this map | 
| 6 | def addString(b: StringBuilder): StringBuilder Appends all elements of this shrinkable collection to a string builder. | 
| 7 | def addString(b: StringBuilder, sep: String): StringBuilder Appends all elements of this shrinkable collection to a string builder using a separator string. | 
| 8 | def apply(key: A): B Returns the value associated with the given key, or the result of the map's default method, if none exists. | 
| 9 | def clear(): Unit Removes all bindings from the map. After this operation has completed, the map will be empty. | 
| 10 | def clone(): Map[A, B] Creates a copy of the receiver object. | 
| 11 | def contains(key: A): Boolean Returns true if there is a binding for key in this map, false otherwise. | 
| 12 | def copyToArray(xs: Array[(A, B)]): Unit Copies values of this shrinkable collection to an array. Fills the given array xs with values of this shrinkable collection. | 
| 13 | def count(p: ((A, B)) => Boolean): Int Counts the number of elements in the shrinkable collection which satisfy a predicate. | 
| 14 | def default(key: A): B Defines the default value computation for the map, returned when a key is not found. | 
| 15 | def drop(n: Int): Map[A, B] Returns all elements except first n ones. | 
| 16 | def dropRight(n: Int): Map[A, B] Returns all elements except last n ones | 
| 17 | def dropWhile(p: ((A, B)) => Boolean): Map[A, B] Drops longest prefix of elements that satisfy a predicate. | 
| 18 | def empty: Map[A, B] Returns the empty map of the same type. | 
| 19 | def equals(that: Any): Boolean Returns true if both maps contain exactly the same keys/values, false otherwise. | 
| 20 | def exists(p: ((A, B)) => Boolean): Boolean Returns true if the given predicate p holds for some of the elements of this shrinkable collection, otherwise false. | 
| 21 | def filter(p: ((A, B))=> Boolean): Map[A, B] Returns all elements of this shrinkable collection which satisfy a predicate. | 
| 22 | def filterKeys(p: (A) => Boolean): Map[A, B] Returns an immutable map consisting only of those key value pairs of this map where the key satisfies the predicate p. | 
| 23 | def find(p: ((A, B)) => Boolean): Option[(A, B)] Finds the first element of the shrinkable collection satisfying a predicate, if any. | 
| 24 | def foreach(f: ((A, B)) => Unit): Unit Applies a function f to all elements of this shrinkable collection. | 
| 25 | def init: Map[A, B] Returns all elements except the last. | 
| 26 | def isEmpty: Boolean Tests whether the map is empty. | 
| 27 | def keys: Iterable[A] Returns an iterator over all keys. | 
| 28 | def last: (A, B) Returns the last element. | 
| 29 | def max: (A, B) Finds the largest element. | 
| 30 | def min: (A, B) Finds the smallest element. | 
| 31 | def mkString: String Displays all elements of this shrinkable collection in a string. | 
| 32 | def product: (A, B) Returns the product of all elements of this shrinkable collection with respect to the * operator in num. | 
| 33 | def remove(key: A): Option[B] Removes a key from this map, returning the value associated previously with that key as an option. | 
| 34 | def retain(p: (A, B) => Boolean): Map.this.type Retains only those mappings for which the predicate p returns true. | 
| 35 | def size: Int Return the number of elements in this map. | 
| 36 | def sum: (A, B) Returns the sum of all elements of this shrinkable collection with respect to the + operator in num. | 
| 37 | def tail: Map[A, B] Returns all elements except the first. | 
| 38 | def take(n: Int): Map[A, B] Returns first n elements. | 
| 39 | def takeRight(n: Int): Map[A, B] Returns last n elements. | 
| 40 | def takeWhile(p: ((A, B)) => Boolean): Map[A, B] Takes longest prefix of elements that satisfy a predicate. | 
| 41 | def toArray: Array[(A, B)] Converts this shrinkable collection to an array. | 
| 42 | def toBuffer[B >: A]: Buffer[B] Returns a buffer containing all elements of this map. | 
| 43 | def toList: List[A] Returns a list containing all elements of this map. | 
| 44 | def toSeq: Seq[A] Returns a seq containing all elements of this map. | 
| 45 | def toSet: Set[A] Returns a set containing all elements of this map. | 
| 46 | def toString(): String Returns a String representation of the object. | 
Scala Maps Summary
- Maps are collections of key-value pairs where each key is unique.
- You can access, add, remove, and check the existence of key-value pairs in a Map.
- You can perform various set operations like union, intersection, and difference on Maps.
- Maps can be used with higher-order functions like map, filter, and foreach.
- Scala supports both mutable and immutable