Kev*_*vin 5 scala future scala-2.8 actor
我在一个主机上启动了两个远程演员,它们只是回显发送给他们的内容.然后我创建另一个actor,它向两个actor发送一些消息(使用!!),并保留一个List of Future对象来保存这些actor的回复.然后我遍历此List获取每个Future的结果.问题在于大多数时候某些期货永远不会回归,甚至认为这位演员声称它已经发出了回复.问题是随机发生的,有时它会通过整个列表,但大多数情况下它会在某个时刻陷入困境并无限期挂起.
以下是一些在我的机器上产生问题的代码:
Sink.scala:
import scala.actors.Actor
import scala.actors.Actor._
import scala.actors.Exit
import scala.actors.remote.RemoteActor
import scala.actors.remote.RemoteActor._
object Sink {
def main(args: Array[String]): Unit = {
new RemoteSink("node03-0",43001).start()
new RemoteSink("node03-1",43001).start()
}
}
class RemoteSink(name: String, port: Int) extends Actor
{
def act() {
println(name+" starts")
trapExit=true
alive(port)
register(Symbol(name),self)
loop {
react {
case Exit(from,reason) =>{
exit()
}
case msg => reply{
println(name+" sending reply to: "+msg)
msg+" back at you from "+name
}
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
Source.scala:
import scala.actors.Actor
import scala.actors.Actor._
import scala.actors.remote.Node;
import scala.actors.remote.RemoteActor
import scala.actors.remote.RemoteActor._
object Source {
def main(args: Array[String]):Unit = {
val peer = Node("127.0.0.1", 43001)
val source = new RemoteSource(peer)
source.start()
}
}
class RemoteSource(peer: Node) extends Actor
{
def act() {
trapExit=true
alive(43001)
register(Symbol("source"),self)
val sinks = List(select(peer,Symbol("node03-0"))
,select(peer,Symbol("node03-1"))
)
sinks.foreach(link)
val futures = for(sink <- sinks; i <- 0 to 20) yield sink !! "hello "+i
futures.foreach( f => println(f()))
exit()
}
}
Run Code Online (Sandbox Code Playgroud)
我究竟做错了什么?
我猜你的问题是由于这一行:
futures.foreach( f => println(f()))
Run Code Online (Sandbox Code Playgroud)
其中你循环遍历所有的 future 并依次阻塞每个 future,等待它的结果。封锁期货通常是一个坏主意,应该避免。相反,您想要做的是指定当未来的结果可用时要执行的操作。尝试这个:
futures.foreach(f => f.foreach(r => println(r)))
Run Code Online (Sandbox Code Playgroud)
这是用 for 理解来表达这一点的另一种方式:
for (future <- futures; result <- future) { println(result) }
Run Code Online (Sandbox Code Playgroud)
这篇博客文章是关于 future 阻塞问题以及 Monadic future 如何克服它的优秀入门读物。
| 归档时间: |
|
| 查看次数: |
754 次 |
| 最近记录: |