私はScalaが初めてで、今日それを学び始めました。Scalaで配列を初期化する方法を知りたいです。
例Javaコード
String[] arr = { "Hello", "World" };
Scalaの上記のコードと同等のものは何ですか?
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]
と同等です。
フィルを使用して、より動的な初期化を行うこともできます。
Array.fill(10){scala.util.Random.nextInt(5)}
==>
Array[Int] = Array(0, 1, 0, 0, 3, 2, 4, 1, 4, 3)
Vasilの回答に追加: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)
2次元配列を使用したいが、その内容がわからない場合は、次を使用できます。
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("", "", ""))