Scala'da başlatılan dizi


115

Scala'da yeniyim, bugün öğrenmeye başladım. Scala'da bir diziyi nasıl başlatacağımı öğrenmek istiyorum.

Örnek Java kodu

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

Yukarıdaki kodun Scala'daki karşılığı nedir?

Yanıtlar:



108

Sıfırlarla dolu bir diziyi başlatmak için şunları kullanabilirsiniz:

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

Bu, Java'nınkine eşdeğerdir new byte[5].


3
Just FYI, List eşdeğer bir başlatıcı olarak List.fill(5)(0), eşit işlevleri kabul eder. List.fill(5)(myFunc())
cevaris

39

Dolgu ile daha dinamik inits de yapabilir, örneğin

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

==>

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

17

Vasil'in cevabına ek olarak: Scala koleksiyonu olarak verilen değerlere sahipseniz yazabilirsiniz.

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

Ancak genellikle toArray yöntemi daha kullanışlıdır:

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

15

Dizi'nin uzunluğunu biliyorsanız ancak içeriğini bilmiyorsanız,

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

İki boyut dizisine sahip olmak istiyorsanız ancak içeriğini bilmiyorsanız,

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

Elbette, String'i başka bir türe değiştirebilirsiniz.

İçeriğini zaten biliyorsanız, kullanabilirsiniz

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

10

Çok boyutlu dizileri bildirmenin başka bir yolu:

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

res3: Array[Array[String]] = Array(Array("", "", ""), Array("", "", ""),Array("", "", ""), Array("", "", ""))
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.