我见过的 Scala 中 Iteratee 模式的 3 个描述都包括 3 个输入案例。例如,来自詹姆斯:
sealed trait Input[+E]
object Input {
case object EOF extends Input[Nothing]
case object Empty extends Input[Nothing]
case class El[+E](e: E) extends Input[E]
}
我的问题很简单:为什么需要Empty输入案例?
迭代模式定义了值流的生产者和消费者之间的关系。直观地说,如果任何输入为空,“运行”迭代器的生产者应该简单地折叠该空项,并且在非空输入可用之前不调用迭代器。
我注意到基于 pull 的 iteratees 类比,更熟悉的迭代器,没有定义一个空的情况,尽管元素可能已经在迭代器的“内部”被过滤掉了。
trait Iterator[E] {
next: E // like El
hasNext: Boolean //like EOF
}
虽然上述所有博客都提到需要一个 Empty 输入,但他们没有明确讨论为什么不能完全消除它。我注意到显示的示例迭代器将空输入视为无操作。
我真的很想要一个带有代码的示例,说明一个看似合理的“现实世界”问题,需要 Empty 输入消息来解决。