询问结果后不等待的模式

问题描述

我有一个akka演员按顺序做一些事情,可以这样总结:

def receive = {
    case Request(...) => {
        val id = generatedId()
        sender() ! id
        doSomeOtherStuffs()
    }
}

使用某些 ask 模式

调用演员
val id = myActor ? Request(...)

这里的问题是代码调用我的演员正在等待所有doSomeOtherStuffs()事情完成。

允许演员回覆然后调用代码停止等待该演员的正确方法是什么?

解决方法

这个怎么样?将其他内容的实际执行与回答请求分离开来

def receive = {
    case Request(...) => {
        val id = generatedId()
        sender() ! id
        self ! DoSomethingElse(...)
    }
    case DoSomethingElse(...) =>
        doSomethingElse()
}

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...