Akka:从回调中向自己发送消息是否安全?

Akka: Is it safe to send a message to self from a callback?

我正在尝试将 SWT 与 Akka 结合使用。其中一个 SWT 小部件是 Browser,它嵌入了 Web 浏览器,并允许 JS 代码通过 BrowserFunction 对象中的回调函数调用 JVM 代码。

我有以下代码:

import org.eclipse.swt.widgets.Composite
import org.eclipse.swt.browser._
import akka.actor.Actor

class MyActor(parentComposite: Composite) extends Actor {
  private var mutableContent: Any = ???

  val browser = new Browser(parentComposite, SWT.BORDER)

  val browserFunction = new BrowserFunction(browser, "JS_CallableFunctionName") {
    val ref = context.self
    override def function(arguments: Array[Object]): Object = {
      ref ! "Is it safe to send a message to myself?"
      null
    }
  }

  def receive = {
    case _ => ???
  }
}

参与者在其中一个回调中向自己发送消息是否有任何风险?

actor给自己发消息应该没有问题。本质上,这只是将消息添加到演员的邮箱中,演员稍后会对其进行处理。当您将参与者的内部变量或状态暴露给外界时,就会出现问题。例如,如果您的 browserFunction return 'mutableContent' 不是这种情况,就会发生这种情况。

也就是说,在我看来,更好的方法是从浏览器中单独创建 Actor,然后安全地将其 ActorRef 传递给 BrowserFunction(也在 Actor 外部创建)。通过这样做,您可以确保您永远不会与在 actor 循环外执行的任何回调共享 actor 的内部状态。任何通信都将通过 Actor 的消息进行。