Koleksi Scala - Streaming

Scala Stream adalah daftar khusus dengan fitur evaluasi malas. Dalam aliran skala, elemen dievaluasi hanya saat dibutuhkan. Stream mendukung komputasi lambat dan memahami performa.

Mendeklarasikan Variabel Stream

Berikut ini adalah sintaks untuk mendeklarasikan variabel Stream.

Sintaksis

val stream = 1 #:: 2 #:: 3 #:: Stream.empty

Di sini, aliran dideklarasikan sebagai aliran angka. Di sini 1 adalah head of stream, 2, 3 adalah tail of stream. Stream.empty menandai akhir dari aliran. Nilai dapat diambil menggunakan perintah take seperti berikut -

Perintah

stream.take(2)

Memproses Streaming

Di bawah ini adalah contoh program yang menunjukkan cara membuat, menginisialisasi, dan memproses Stream -

Contoh

import scala.collection.immutable.Stream
object Demo {
   def main(args: Array[String]) = {
      val stream = 1 #:: 2 #:: 3 #:: Stream.empty
      // print stream
      println(stream)
      // Print first two elements	
      stream.take(2).print
      println()
      // Create an empty stream
      val stream1: Stream[Int] = Stream.empty[Int]
      // Print element
      println(s"Stream: $stream1")
   }
}

Simpan program di atas dalam Demo.scala. Perintah berikut digunakan untuk mengkompilasi dan menjalankan program ini.

Perintah

\>scalac Demo.scala
\>scala Demo

Keluaran

Stream(1, <not computed>)
1, 2
Stream: Stream()