我无法让儿童演员接收消息

Posted

技术标签:

【中文标题】我无法让儿童演员接收消息【英文标题】:I can't get a child actor to receive messages 【发布时间】:2016-10-01 12:34:53 【问题描述】:

我是 akka 的新手,我想知道如何让子 actor 接收消息。

我有一个父actor打印出它收到一条消息,然后发送一条消息给它的孩子,然后它打印出它收到一条消息。

当我运行程序时,只有父actor打印它的消息。有没有 我错过了什么?

父演员

class TestDirector(name: String) extends Actor 
  import TestDirector._

  implicit val timeout = Timeout(5.seconds)

  private var child: ActorRef = _

  override def preStart(): Unit = 
    println(name + " pre-start")
    child = context.actorOf(props("test-file"), name = "child-actor")
  

  override def receive: Receive = 
    case TestDirectory(dir) =>
      println("Test Director")
      child ! TestWorker.TestFile
  



object TestDirector 
  case class TestDirectory(dirName: String)
  case class TestResponse(message: String)

  def props(dirName: String) = Props(classOf[TestDirector], dirName)


童星

class TestWorker(fileName: String) extends Actor 
  import TestWorker._

  override def receive: Receive = 
    case TestFile => println("Hello world")
  



object TestWorker 
  case object TestFile

  def props(fileName: String) = Props(classOf[TestWorker], fileName)

【问题讨论】:

【参考方案1】:

在TestDirector.preStart中,你说

    child = context.actorOf(props("test-file"), name = "child-actor")

那些“道具”是 TestDirector.props,您在上面导入了几行,因此您无休止地创建新的 TestDirector。我认为您想要的是 TestWorker.props:

    child = context.actorOf(TestWorker.props("test-file"), name = "child-actor")

【讨论】:

以上是关于我无法让儿童演员接收消息的主要内容,如果未能解决你的问题,请参考以下文章

深潜Kotlin协程(十七):演员

深潜Kotlin协程(十七):演员

如何在 Scala 中优先考虑演员之间发送的消息?

在 Akka 中创建演员的成本是多少?

无法确认正在创建任何演员

演员模型:一个演员需要来自另一个演员的信息