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方法所有代碼貼出來
相關文章:
