1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
|
@deprecated("Suppress warnings", since="2.11")
object Test {
import scala.actors._, scala.actors.Actor._, scala.actors.Futures._
def main(args: Array[String]) {
actor {
val C: Channel[Int] = new Channel[Int](self)
def respondAll(fts: List[Future[Int]], cnt: Int): Unit =
fts match {
case List() => C ! 0
case ft :: rest =>
if (cnt % 100 == 0)
println(ft())
respondAll(rest, cnt + 1)
}
actor {
val fts = for (_ <- 1 to 1000)
yield C !! (3, {case x: Int => x})
actor {
respondAll(fts.toList, 0)
}
}
loop {
C.react {
case 0 => exit()
case i => reply(i * 2)
}
}
}
}
}
|