scala - 即使没有匹配项,如何始终在接收()中调用方法

标签 scala akka

我对 Akka/Scala 世界相当陌生。我试图找出在 Actor 接收消息时始终执行某事的最佳方式是什么,即使没有匹配的消息也是如此。我知道receivePartialFunction但我想知道是否有比以下更好的方法:

def receive: Receive = {
  case string: String => { 
    functionIWantToCall()
    println(string)
  }
  case obj: MyClass => {
    functionIWantToCall()
    doSomethingElse()
  }
  case _ => functionIWantToCall()
}

我很确定 Scala 中有更好的方法来执行此操作,而不是调用 functionIWantToCall()在每个案例中。有人可以提出一些建议:)?

最佳答案

您可以将 Receive 函数包装在“高阶”Receive 函数中

  def withFunctionToCall(receive: => Receive): Receive = {
    // If underlying Receive is defined for message
    case x if receive.isDefinedAt(x) =>
      functionIWantToCall()
      receive(x)

    // Only if you want to catch all messages
    case _ => functionIWantToCall()
  }

  def receive: Receive = withFunctionToCall {
    case string: String => println(string)
    case obj: MyClass => doSomethingElse()
  }

或者您可以在 Akka 文档中阅读有关管道的信息:http://doc.akka.io/docs/akka/snapshot/contrib/receive-pipeline.html

我认为这正是您解决此类问题所需要的
  val callBefore: Receive => Receive =
    inner ⇒ {
      case x ⇒ functionIWantToCall; inner(x)
    }

  val myReceive: Receive = {
    case string: String => println(string)
    case obj: MyClass => doSomethingElse()
  }

  def receive: Receive = callBefore(myReceive)

关于scala - 即使没有匹配项,如何始终在接收()中调用方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26706177/

相关文章:

scala - SBT:值(value)与应用

java - 将 java enum 转换为 scala Enumeration 以进行 json4s 序列化

java - Akka Actor (Scala) 如何获取内存不足的堆转储

scala - Scala 和 Akka 中的 Future

scala - Akka-http logrequest 不记录请求正文

scala - 如何在 netbeans (Windows) 上使用 scala

scala - 在 Scala/Play 中组合多个 Try 对象

java - Scala.List 和 Java.util.List 之间的互操作

scala - 升级到1.2版本后,将Marshaller的 future 未纳入隐含范围

java - 同步(或 future 返回)调用 Akka UntypedPersistentActor?