blob: fcc439b488d9458d2a40d4af5a24f11353f808e3 (
plain) (
blame)
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
|
import scala.actors._, scala.actors.Actor._, scala.actors.Futures._
object Test {
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)
}
}
}
}
}
|