这可能是一个非常简单的错误,但我无法让它正常工作.我正在使用akka 2.2.3在scala中创建一个基于actor的应用程序.
简化的设置如下:
object Main {
def main(args: Array[String]) = {
val system = ActorSystem("Test")
val discoverer = system.actorOf(Props[Discoverer], "discoverer")
implicit val timeout = Timeout(5.seconds)
val not = discoverer ? Messages.Find(something)
not.onComplete {
case Success(va) => println(va)
case Failure(err) => println(err)
}
...
}
}
Run Code Online (Sandbox Code Playgroud)
和主要演员
class Discoverer extends Actor {
override def preStart() = {
val refresher = context.actorOf(Props[Refresher], "refresher")
refresher ! Refresh
}
def receive = {
case _ => sender ! Answer
}
}
Run Code Online (Sandbox Code Playgroud)
和Refresher
演员
class Refresher extends Actor {
...
}
Run Code Online (Sandbox Code Playgroud)
你应该从中得到的是,我的演员都没有参数化构造函数.
但是,如果我尝试运行我的应用程序,它将失败
[ERROR] [12/09/2013 13:17:06.893] [Test-akka.actor.default-dispatcher-3]
[akka://Test/user/discoverer] no matching constructor found on
class Discoverer$Refresher for arguments []
Run Code Online (Sandbox Code Playgroud)
我的错误是什么?我不应该创建我的演员.actorOf(Props[Class], "actorname")
吗?
cmb*_*ter 12
如果你想使用嵌套类来实现这个功能,你需要实例化嵌套的actor,它将对封闭actor的引用作为构造函数arg传递.你看到的错误是说没有no-args
构造函数,所以这是一个提示.使事情有效的代码如下所示:
object InnerTest {
def main(args: Array[String]) {
val sys = ActorSystem("test")
sys.actorOf(Props[OuterActor])
}
}
class OuterActor extends Actor{
override def preStart = {
context.actorOf(Props(classOf[InnerActor], this), "my-inner-actor")
}
def receive = {
case _ =>
}
class InnerActor extends Actor{
def receive = {
case _ =>
}
}
}
Run Code Online (Sandbox Code Playgroud)
我的猜测是,这与尝试实例化非静态内部类(通过反射)而不提供对它的外部类的引用有关.我通过阅读这篇文章来确定这一点:
https://www.assembla.com/spaces/akka/tickets/3675#/activity/ticket: