Відповіді:
scala> val arr = Array("Hello","World")
arr: Array[java.lang.String] = Array(Hello, World)
Для ініціалізації масиву, заповненого нулями, ви можете використовувати:
> Array.fill[Byte](5)(0)
Array(0, 0, 0, 0, 0)
Це еквівалентно Java new byte[5]
.
List.fill(5)(0)
, приймає навіть функції. List.fill(5)(myFunc())
Також можна зробити більш динамічні вставки з заливкою, наприклад
Array.fill(10){scala.util.Random.nextInt(5)}
==>
Array[Int] = Array(0, 1, 0, 0, 3, 2, 4, 1, 4, 3)
Додатково до відповіді Василя: Якщо у вас є значення, наведені як колекція Scala, ви можете написати
val list = List(1,2,3,4,5)
val arr = Array[Int](list:_*)
println(arr.mkString)
Але зазвичай метод toArray є більш зручним:
val list = List(1,2,3,4,5)
val arr = list.toArray
println(arr.mkString)
Якщо ви знаєте довжину масиву, але не знаєте його вмісту, ви можете використовувати
val length = 5
val temp = Array.ofDim[String](length)
Якщо ви хочете мати масив двох вимірів, але ви не знаєте його вмісту, ви можете використовувати
val row = 5
val column = 3
val temp = Array.ofDim[String](row, column)
Звичайно, ви можете змінити String на інший тип.
Якщо ви вже знаєте його вміст, ви можете використовувати
val temp = Array("a", "b")
Ще один спосіб оголошення багатовимірних масивів:
Array.fill(4,3)("")
res3: Array[Array[String]] = Array(Array("", "", ""), Array("", "", ""),Array("", "", ""), Array("", "", ""))