java - AKKA actor創(chuàng)建錯誤
問題描述
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) 這行代碼在執(zhí)行的時候出錯了,拋出了異常
第二中寫法這種寫法就沒有錯誤:val master = actorSystem.actorOf(Props(new Master(host, port)), 'Master')
第二種寫法中也會是首先執(zhí)行new Master(host,port),為什么第二種寫法中就沒有拋出異常呢???
以上兩種寫法都是會首先執(zhí)行new Master的。
已知:actor的創(chuàng)建需要有繼承體系,實例是不能直接使用new 來創(chuàng)建的。而是使用系統(tǒng)的actorOf方法來創(chuàng)建,注意Actor之間有層次關(guān)系(和人類社會一樣)。
問題: 第二中寫法也是直接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,結(jié)果就是運行不起來,直接報錯 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的工廠方法創(chuàng)建的么?把你的main方法所有代碼貼出來
相關(guān)文章:
1. 如何解決docker宿主機無法訪問容器中的服務(wù)?2. angular.js - 輸入郵箱地址之后, 如何使其自動在末尾添加分號?3. javascript - 如何使用nodejs 將.html 文件轉(zhuǎn)化成canvas4. javascript - html5的data屬性怎么指定一個function函數(shù)呢?5. docker-compose中volumes的問題6. 在mac下出現(xiàn)了兩個docker環(huán)境7. python - Scrapy存在內(nèi)存泄漏的問題。8. javascript - 后臺管理系統(tǒng)左側(cè)折疊導(dǎo)航欄數(shù)據(jù)較多,怎么樣直接通過搜索去定位到具體某一個菜單項位置,并展開當前菜單9. angular.js - $stateChangeSuccess事件在狀態(tài)跳轉(zhuǎn)的時候不執(zhí)行?10. java如何生成token?
