java - AKKA actor创建错误
问题描述
class Master(val host: String, val port: Int) extends Actor 第一种写法val masterActor=new Master(host, port)val master = actorSystem.actorOf(Props(masterActor), 'Master')
Exception in thread 'main' akka.actor.ActorInitializationException: You cannot create an instance of [test.rpc.Master] explicitly using the constructor (new). You have to use one of the ’actorOf’ factory methods to create a new actor. See the documentation.
at akka.actor.ActorInitializationException$.apply(Actor.scala:167)at akka.actor.Actor$class.$init$(Actor.scala:423)at test.rpc.Master.<init>(Master.scala:13)at test.rpc.Master$.main(Master.scala:106)at test.rpc.Master.main(Master.scala)at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)at java.lang.reflect.Method.invoke(Method.java:606)at com.intellij.rt.execution.application.AppMain.main(AppMain.java:147)
You cannot create an instance of [test.rpc.Master] explicitly using the constructor (new). You have to use one of the ’actorOf’ factory methods to create a new actor.
错误的代码是:val masterActor=new Master(host, port) 这行代码在执行的时候出错了,抛出了异常
第二中写法这种写法就没有错误:val master = actorSystem.actorOf(Props(new Master(host, port)), 'Master')
第二种写法中也会是首先执行new Master(host,port),为什么第二种写法中就没有抛出异常呢???
以上两种写法都是会首先执行new Master的。
已知:actor的创建需要有继承体系,实例是不能直接使用new 来创建的。而是使用系统的actorOf方法来创建,注意Actor之间有层次关系(和人类社会一样)。
问题: 第二中写法也是直接new了actor 就没报错,原因是什么那
main方法主要代码:
def main(args: Array[String]): Unit = { val host = args(0) val port = args(1).toInt println(host) println(port) val config = ...... val actorSystem = ActorSystem('MasterSystem', config)//第一中方式,自己new,结果就是运行不起来,直接报错 val masterActor= new Master(host, port) val master = actorSystem.actorOf(Props(masterActor), 'Master') //第二种方式, 这行代码中也有new Master,但是程序可以正常运行,不会出错val master = actorSystem.actorOf(Props(new Master(host, port)), 'Master') actorSystem.awaitTermination() }
问题解答
回答1:第二种哪里是直接new了,不是actorSystem的工厂方法创建的么?把你的main方法所有代码贴出来
相关文章:
1. java - 用IDEA搭建SSM框架单元测试时候报错2. javascript - 关于微信公众号开发的一个trouble!3. docker - MySQL 报错:Access denied for user ’xxx’@’localhost’4. javascript - 微信jssdk ios下自定义onMenuShareAppMessage 分享失效,Android分享成功5. css3怎么限定文字字数6. 微信公众号发送模板消息返回错误410007. 在windows下安装docker Toolbox 启动Docker Quickstart Terminal 失败!8. 创建mysqli对象与数据库连接 - 出错9. Android明明可以直接分享,为什么还要用微信开放平台、微博开放平台的sdk?10. 如何用html5开发app?ide是netbeans
