質問

私は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)

もちろん、文字列を他のタイプに変更できます。

あなたがすでにそのコンテンツを知っているなら、あなたは使用できます

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

多級配列を宣言する別の方法:

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

res3: Array[Array[String]] = Array(Array("", "", ""), Array("", "", ""),Array("", "", ""), Array("", "", ""))
ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top