1 つのホストで 2 つのリモート アクターを開始し、送信されたものをすべてエコーします。次に、( !! を使用して) いくつかのメッセージを両方のアクターに送信する別のアクターを作成し、これらのアクターからの応答を保持する Future オブジェクトのリストを保持します。次に、この 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
}
}
}
}
}
ソース.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()
}
}
私は何を間違っていますか?