Scalaでの配列の初期化


115

私はScalaを使い始めたばかりですが、今日それを学び始めました。Scalaで配列を初期化する方法を知りたいのですが。

Javaコードの例

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

上記のScalaのコードに相当するものは何ですか?

回答:



108

ゼロで満たされた配列を初期化するには、以下を使用できます。

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

これはJavaのと同等new byte[5]です。


3
参考までに、同等の初期化子としてのListは、List.fill(5)(0)関数も受け入れます。List.fill(5)(myFunc())
cevaris

39

フィルでより動的な初期化を行うこともできます。

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

==>

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

17

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)

15

配列の長さがわかっていて、その内容がわからない場合は、

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")

10

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

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

res3: Array[Array[String]] = Array(Array("", "", ""), Array("", "", ""),Array("", "", ""), Array("", "", ""))
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.