Array initialisant dans Scala


115

Je suis nouveau sur Scala, je viens de commencer à l'apprendre aujourd'hui.J'aimerais savoir comment initialiser un tableau dans Scala.

Exemple de code Java

String[] arr = { "Hello", "World" };

Quel est l'équivalent du code ci-dessus dans Scala?

Réponses:



108

Pour initialiser un tableau rempli de zéros, vous pouvez utiliser:

> Array.fill[Byte](5)(0)
Array(0, 0, 0, 0, 0)

Ceci est équivalent à celui de Java new byte[5].


3
Juste pour info, List comme initialiseur équivalent List.fill(5)(0), accepte même les fonctions. List.fill(5)(myFunc())
cevaris

39

Peut également faire des inits plus dynamiques avec fill, par exemple

Array.fill(10){scala.util.Random.nextInt(5)} 

==>

Array[Int] = Array(0, 1, 0, 0, 3, 2, 4, 1, 4, 3)

17

En plus de la réponse de Vasil: si vous avez les valeurs données en tant que collection Scala, vous pouvez écrire

val list = List(1,2,3,4,5)
val arr = Array[Int](list:_*)
println(arr.mkString)

Mais en général, la méthode toArray est plus pratique:

val list = List(1,2,3,4,5)
val arr = list.toArray
println(arr.mkString)

15

Si vous connaissez la longueur de Array mais que vous ne connaissez pas son contenu, vous pouvez utiliser

val length = 5
val temp = Array.ofDim[String](length)

Si vous souhaitez avoir un tableau à deux dimensions mais que vous ne connaissez pas son contenu, vous pouvez utiliser

val row = 5
val column = 3
val temp = Array.ofDim[String](row, column)

Bien sûr, vous pouvez changer String en un autre type.

Si vous connaissez déjà son contenu, vous pouvez utiliser

val temp = Array("a", "b")

10

Une autre façon de déclarer des tableaux multidimensionnels:

Array.fill(4,3)("")

res3: Array[Array[String]] = Array(Array("", "", ""), Array("", "", ""),Array("", "", ""), Array("", "", ""))
En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.