scala和java中的枚举器vs迭代器

时间:2013-02-22 20:14:38

标签: java scala playframework iterate

Enumerator和Iterator有什么区别?根据我的理解Enumerator并不是Java中enum的精美别名。相反,它似乎是一种类似于Iterator的遍历技术。那么有人能够比较和对比EnumeratorIterator吗?另外,我在Play中看到了

的用法
val data = getDataStream
val dataContent: Enumerator[Array[Byte]] = Enumerator.fromStream(data)

编辑:

我倾向于认为Enumerator为我们提供了实际的数据块,而Iterator为我们提供了已经分块的数据的指针,例如列表。但我不相信情况就是这样。

1 个答案:

答案 0 :(得分:9)

EnumeratorPlay class,而不是Java或Scala。

它是Play提供的Iteratee I / O处理的一部分。 Iteratees是一个有趣的野兽 - 一方面,它“将”数据“推送”到处理程序,而不是依靠处理程序来提取数据,因此具有更好的性能。在其他手上,它允许处理程序控制何时应该停止流。最后,可以组成迭代,以便不同的迭代负责输入的不同部分(比如,一个接收HTTP头,另一个接收它的主体)以及链接它们,因此低级迭代可以进行预处理,这是然后喂给更高级别的迭代者。

它们上面有很多材料,可以利用它。

以任何方式与迭代器或枚举相关。