Array inicializando em Scala


115

Sou novo em Scala, comecei a aprender hoje. Gostaria de saber como inicializar um array em Scala.

Exemplo de código Java

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

Qual é o equivalente ao código acima no Scala?

Respostas:



108

Para inicializar uma matriz preenchida com zeros, você pode usar:

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

Isso é equivalente ao de Java new byte[5].


3
Apenas FYI, List como um inicializador equivalente List.fill(5)(0), aceita funções pares. List.fill(5)(myFunc())
cevaris

39

Também pode fazer inits mais dinâmicos com preenchimento, por exemplo

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

==>

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

17

Adicional à resposta de Vasil: Se você tiver os valores fornecidos como uma coleção Scala, você pode escrever

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

Mas geralmente o método toArray é mais útil:

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

15

Se você sabe o comprimento do Array, mas não conhece seu conteúdo, você pode usar

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

Se você deseja ter uma matriz de duas dimensões, mas não conhece seu conteúdo, você pode usar

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

Claro, você pode alterar String para outro tipo.

Se você já conhece seu conteúdo, pode usar

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

10

Outra maneira de declarar matrizes multidimensionais:

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

res3: Array[Array[String]] = Array(Array("", "", ""), Array("", "", ""),Array("", "", ""), Array("", "", ""))
Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.