layout | title | partof | num | next-page | previous-page | topics | redirect_from |
---|---|---|---|---|---|---|---|
tour |
Tuples |
scala-tour |
8 |
mixin-class-composition |
traits |
tuples |
/tutorials/tour/tuples.html |
In Scala, a tuple is a value that contains a fixed number of elements, each with its own type. Tuples are immutable.
Tuples are especially handy for returning multiple values from a method.
A tuple with two elements can be created as follows:
{% tabs tuple-construction %}
{% tab 'Scala 2 and 3' for=tuple-construction %}
val ingredient = ("Sugar", 25)
{% endtab %}
{% endtabs %}
This creates a tuple containing a String
element and an Int
element.
The inferred type of ingredient
is (String, Int)
.
{% tabs tuple-indexed-access class=tabs-scala-version %}
{% tab 'Scala 2' for=tuple-indexed-access %}
One way of accessing tuple elements is their positions.
The individual elements are named _1
, _2
, and so forth.
println(ingredient._1) // Sugar
println(ingredient._2) // 25
{% endtab %}
{% tab 'Scala 3' for=tuple-indexed-access %}
One way of accessing tuple elements is their positions.
The individual elements are accessed with tuple(0)
, tuple(1)
, and so forth.
println(ingredient(0)) // Sugar
println(ingredient(1)) // 25
{% endtab %}
{% endtabs %}
A tuple can also be taken apart using pattern matching:
{% tabs tuple-extraction %}
{% tab 'Scala 2 and 3' for=tuple-extraction %}
val (name, quantity) = ingredient
println(name) // Sugar
println(quantity) // 25
{% endtab %}
{% endtabs %}
Here name
's inferred type is String
and quantity
's inferred type
is Int
.
Here is another example of pattern-matching a tuple:
{% tabs tuple-foreach-patmat %}
{% tab 'Scala 2 and 3' for=tuple-foreach-patmat %}
val planets =
List(("Mercury", 57.9), ("Venus", 108.2), ("Earth", 149.6),
("Mars", 227.9), ("Jupiter", 778.3))
planets.foreach {
case ("Earth", distance) =>
println(s"Our planet is $distance million kilometers from the sun")
case _ =>
}
{% endtab %}
{% endtabs %}
Or, in a for
comprehension:
{% tabs tuple-for-extraction class=tabs-scala-version %}
{% tab 'Scala 2' for=tuple-for-extraction %}
val numPairs = List((2, 5), (3, -7), (20, 56))
for ((a, b) <- numPairs) {
println(a * b)
}
{% endtab %}
{% tab 'Scala 3' for=tuple-for-extraction %}
val numPairs = List((2, 5), (3, -7), (20, 56))
for (a, b) <- numPairs do
println(a * b)
{% endtab %}
{% endtabs %}
Users may sometimes find it hard to choose between tuples and case classes. Case classes have named elements. The names can improve the readability of some kinds of code. In the planet example above, we might define case class Planet(name: String, distance: Double)
rather than using tuples.
- Learn more about tuples in the Scala Book