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. android - mac平台运行快捷键咋按2. 下一个页面的三角在上面一个页面会出现,在缩放的时候会遮住文字。3. mysql优化 - mysql 多表联合查询,求一个效率最高的查询4. php由5.3升级到5.6后,登录网站,返回的是php代码,不是登录界面,各位大神有知道的吗?5. weex - Android 原生Vue.js 使用 justify-content: flex-end; 不起作用6. 数据库 - mysql中怎样修改带点的字段名的位置?7. python - Django ManyToManyField 字段数据在 admin后台 显示不正确,这是怎么回事?8. javascript - vue-cli热更新的问题【webpack配置】9. 为什么span的color非要内联样式才起作用?10. mysql 能不能创建一个 有列级函数 的联合视图?

网公网安备