2

Scala2.8Continuations-PlugInを使用して次の単純なジェネレーターを構築してみます。次のエラーはどこから発生しますか?

None/None/Some((Unit,Unit))
GenTest.scala:8: error: found cps expression in non-cps position
        yieldValue(1)

None/None/Some((Unit,Unit))
GenTest.scala:9: error: found cps expression in non-cps position
        yieldValue(2)

None/None/Some((Unit,Unit))
GenTest.scala:10: error: found cps expression in non-cps position
        yieldValue(3)

コード:

import scala.util.continuations._

object GenTest {

    val gen = new Generator1[Int] {
        yieldValue(1)
        yieldValue(2)
        yieldValue(3)
    }

    def main(args: Array[String]): Unit = {
        for (v <- gen) {
            println(v)
        }
    }
}



class Generator1[E](gen: => Unit @cps[Unit]) {

  var loop: (E => Unit) = null

  def foreach(f: => (E => Unit)): Unit = {
        loop = f
        reset[Unit,Unit]( gen )
  }

  def yieldValue(value: E): Unit @cps[Unit] =
    shift { genK: (Unit => Unit) =>
      loop( value )
      genK( () )
      ()
    }
}
4

1 に答える 1

1

これらのyieldValue呼び出しはgen、のコンストラクター内で発生していますが、これは許可されていません(私は推測します)。ああ、コンストラクターパラメーターを意図していることに気づきました。残念ながら、その構文はメソッドでのみ機能します。ここでも別のエラーが発生しないかどうかはわかりません。

于 2010-04-15T14:49:06.293 に答える