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. docker安裝后出現Cannot connect to the Docker daemon.2. Docker for Mac 創建的dnsmasq容器連不上/不工作的問題3. 刷新頁面出現彈框4. javascript - 編程,算法的問題5. javascript - 怎么看網站用了什么技術框架?6. mysql - 用PHPEXCEL將excel文件導入數據庫數據5000+條,本地數據庫正常,線上只導入15條,沒有報錯,哪里的問題?7. javascript - 請教空白文本節點的問題8. PC 手機兼容的 編輯器9. 關于Android權限的獲取問題,大家遇到過這樣的情況嘛?10. css - 關于border-image
