考虑这两个特点:
trait Poked extends Actor {
override def receive = {
case Poke(port, x) => ReceivePoke(port, x)
}
def ReceivePoke(port: String, x: Any)
}
trait Peeked extends Actor {
override def receive = {
case Peek(port) => ReceivePeek(port)
}
def ReceivePeek(port: String)
}
现在考虑我可以创建一个实现这两个特质的新Actor:
val peekedpoked = actorRef(new Actor extends Poked with Peeked)
如何组合接收处理程序?即,接收器应该像以下代码一样,“自动生成”(即,所有特性应该组合):
def receive = (Poked.receive: Receive) orElse (Peeked.receive: Receive) orElse ...