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
|
@deprecated("Suppress warnings", since="2.11")
object Test {
import scala.actors._, scala.actors.Actor._, scala.actors.Futures._
def main(args: Array[String]) {
val a = actor {
loop { react {
case i: Int => reply(i * 2)
case 'stop => exit()
} }
}
val fts = for (_ <- 1 to 1000)
yield a !! (3, {case x: Int => x})
def respondAll(fts: List[Future[Int]], cnt: Int): Unit =
fts match {
case List() => a ! 'stop
case ft :: rest =>
if (cnt % 100 == 0)
println(ft())
respondAll(rest, cnt + 1)
}
actor {
respondAll(fts.toList, 0)
}
}
}
|