- Scala 集合教程
- Scala 集合 - 主页
- Scala 集合 - 概述
- Scala 集合 - 环境设置
- Scala 集合 - 数组
- Scala 集合 - 数组
- Scala 集合 - 多维数组
- Scala 集合 - 使用范围的数组
- Scala 集合 - ArrayBuffer
- Scala 集合 - 列表
- Scala 集合 - 列表
- Scala 集合 - ListBuffer
- Scala 集合 - ListSet
- Scala 集合-矢量
- Scala 集合 - 集
- Scala 集合 - 集
- Scala 集合 - BitSet
- Scala 集合 - HashSet
- Scala 集合 - TreeSet
- Scala 集合 - 地图
- Scala 集合 - 地图
- Scala 集合 - HashMap
- Scala 集合 - ListMap
- Scala 集合 - 杂项
- Scala 集合 - 迭代器
- Scala 集合 - 选项
- Scala 集合 - 队列
- Scala 集合 - 元组
- Scala 集合 - Seq
- Scala 集合 - 堆栈
- Scala 集合 - Stream
- Scala 集合组合器方法
- Scala 集合 - drop
- Scala 集合 - dropWhile
- Scala 集合 - 过滤器
- Scala 集合 - 查找
- Scala 集合 - flatMap
- Scala 集合 - 展平
- Scala 集合 - 折叠
- Scala 集合 - FoldLeft
- Scala 集合 - FoldRight
- Scala 集合 - 地图
- Scala 集合 - 分区
- Scala 集合 - 减少
- Scala 集合 - 扫描
- Scala 集合 - zip
- Scala 集合有用的资源
- Scala 集合 - 快速指南
- Scala 集合 - 有用的资源
- Scala 集合 - 讨论
Scala 集合 - Stream
Scala Stream 是具有延迟计算功能的特殊列表。在 scala 流中,元素仅在需要时才被求值。Stream 支持惰性计算并且具有高性能。
声明流变量
以下是声明 Stream 变量的语法。
句法
val stream = 1 #:: 2 #:: 3 #:: Stream.empty
这里,stream 被声明为数字流。这里1是流的头部,2、3是流的尾部。Stream.empty 标记流的结束。可以使用如下命令检索值 -
命令
stream.take(2)
处理流
下面是一个示例程序,展示了如何创建、初始化和处理流 -
例子
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") } }
将上述程序保存在Demo.scala中。以下命令用于编译和执行该程序。
命令
\>scalac Demo.scala \>scala Demo
输出
Stream(1, <not computed>) 1, 2 Stream: Stream()