Inizializzazione di array in Scala


115

Sono nuovo in Scala, ho appena iniziato ad impararlo oggi. Vorrei sapere come inizializzare un array in Scala.

Esempio di codice Java

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

Qual è l'equivalente del codice sopra in Scala?

Risposte:



108

Per inizializzare un array riempito di zeri, puoi usare:

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

Questo è equivalente a Java new byte[5].


3
FYI, List come un inizializzatore equivalente List.fill(5)(0), accetta anche funzioni. List.fill(5)(myFunc())
cevaris

39

Può anche eseguire init più dinamici con riempimento, ad es

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

==>

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

17

In aggiunta alla risposta di Vasil: se hai i valori dati come collezione Scala, puoi scrivere

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

Ma di solito il metodo toArray è più utile:

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

15

Se conosci la lunghezza di Array ma non ne conosci il contenuto, puoi usare

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

Se vuoi avere un array a due dimensioni ma non ne conosci il contenuto, puoi usare

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

Ovviamente puoi cambiare String in un altro tipo.

Se conosci già il suo contenuto, puoi usare

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

10

Un altro modo per dichiarare array multidimensionali:

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

res3: Array[Array[String]] = Array(Array("", "", ""), Array("", "", ""),Array("", "", ""), Array("", "", ""))
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.