0
我有以下类:如何将PartialFunction与另一个函数结合并返回PartialFunction?
class MessageProcessorActor(private val destination : ActorRef) extends Actor{
override def receive: Receive = {
case _ =>
destination ! {
case MyActor.TracableMessage(msg) => MyActor.TracableMessage("Processed + " + msg)
case MyActor.Message(msg) => MyActor.Message("Processed + " + msg)
case _ => "Processed + " + _
}(_)
}
}
object MyActor{
case class TracableMessage(private val msg: String) extends Message(msg)
case class Message(private val msg: String)
}
凡为
type Receive = PartialFunction[Any, Unit]
在这里,我试图避免宣布val
拿着PartialFunction[Any, Any]
并调用它这样Recieve
定义。但编译器拒绝此代码。它打印:
Error:(12, 6) ';' expected but '(' found.
}(_)
^
是否有一个简短的方法来做这样的事情?
是的,它确实有效,但我试图避免多个'目的地! msg'表达。并只写一次(而不是三次)。 – user3663882
会有什么好处? –