作为一个 Scala 初学者,我试图为表达式Iterator
中检索和处理的每个项目实现一个计数器,并且每次在for
表达式的一个“循环”(外循环和嵌套循环)开始。counter = counter + 1
要求是在不简单地在表达式中的多个位置放置语句的情况下完成此操作for
。下面的清单显示了我对这个问题提出的解决方案,我想知道,为什么方法next
实现Iterator
的抽象成员被调用(并且相应的计数器增加),而flatMap
覆盖map
它们在 trait 中定义的挂件Iterator
(并通过调用它们super
)不是根本就叫。
object ZebraPuzzle {
var starts = 0
var items = 0
class InstrumentedIter[A](it: Iterator[A]) extends Iterator[A] {
private val iterator = it
def hasNext = it.hasNext
def next() = {
items = items + 1
it.next()
}
override def flatMap[B](f: (A) ⇒ GenTraversableOnce[B]): Iterator[B] = {
starts = starts + 1
super.flatMap(f)
}
override def map[B](f: (A) ⇒ B): Iterator[B] = {
starts = starts + 1
super.map(f)
}
} // inner class InstrumentedIter
对应的for
表达式如下所示:
def solve = {
val first = 1
val middle = 3
val houses = List(first, 2, middle, 4, 5)
for {
List(r, g, i, y, b) <- new InstrumentedIter(houses.permutations)
if ...
List(eng, span, ukr, jap, nor) <- new InstrumentedIter(houses.permutations)
if ...
if ...
if ...
List(of, tea, milk, oj, wat) <- new InstrumentedIter(houses.permutations)
if ...
...
} yield ...
...
}
...
} // standalone singleton object ZebraPuzzle
如果有人能给我提示如何以更好的方式解决给定的问题,我将不胜感激。但最重要的是,我很想知道为什么我的解决方案会覆盖Iterator
'smap
并且flatMap
不像我有限的大脑所期望的那样工作;-)
问候
马丁