我试图从readLine调用中创建无限的字符串流:
import java.io.{BufferedReader, InputStreamReader}
val in = new BufferedReader(new InputStreamReader(System in))
val input: Stream[String] = Stream.cons(in readLine, input)但是看起来readLine调用并没有被懒惰地调用。在输入该代码后,readLine立即期望输入,然后流变成相同输入的无限列表。有可能实现我心目中的目标吗?
发布于 2010-07-22 16:58:34
import java.io.{BufferedReader, InputStreamReader}
val in = new BufferedReader(new InputStreamReader(System in))
val input = Stream.continually(in readLine)发布于 2010-07-22 14:46:19
请参阅Stream上的示例。请注意,懒惰的thunk在尾部,而不是头部。每次调用thunk时,它都应该返回下一个cons (包括下一个thunk,它应该提供下一个cons,包括...)
这是Stream.cons的签名:[http://www.scala-lang.org/docu/files/api/scala/collection/immutable/Stream](http://www.scala-lang.org/docu/files/api/scala/collection/immutable/Stream)$$cons$.html。注意作为apply的第二个参数的thunk (=>流)。
https://stackoverflow.com/questions/3306202
复制相似问题