在我的项目中,我必须使用参与者和调度程序。我所有的需求只能通过使用一个actor系统来完成。但是我需要一个以上班级的调度员和演员。所以我的问题是,如果我应该像下面那样在每个类中注入actor系统,它将创建一个actor系统还是一个以上actor系统?我不希望创建多个参与者系统,因为这不是推荐的做法。
import akka.actor.ActorSystem
@Singleton
class someClass @Inject()(actorSystem: ActorSystem){....} // abstract class ActorSystem extends ActorRefFactory
@Singleton
class anotherClass @Inject()(actorSystem: ActorSystem){....}
或者我应该创建另一个对象,并在其中声明一个actor系统,并像这样在各处使用它:
import akka.actor._
object actorSystemObject {
val system: ActorSystem = ActorSystem()
}
哪种方法更好,更标准?
答案 0 :(得分:4)
假设您正在使用guice,请像这样尝试providing和singleton
@Provides
@Singleton
def getActorSystem: ActorSystem = ActorSystem()
例如
import akka.actor.ActorSystem
import com.google.inject.{AbstractModule, Guice, Inject, Injector, Provides, Singleton}
import scala.jdk.CollectionConverters._
class MyModule extends AbstractModule {
@Provides
@Singleton
def getActorSystem: ActorSystem = ActorSystem()
}
@Singleton
class SomeClass @Inject()(actorSystem: ActorSystem) {
println(actorSystem.hashCode())
}
@Singleton
class SomeOtherClass @Inject()(actorSystem: ActorSystem) {
println(actorSystem.hashCode())
}
object Hello extends App {
val injector: Injector = Guice.createInjector(List(new MyModule).asJava)
injector.getInstance(classOf[SomeClass])
injector.getInstance(classOf[SomeOtherClass])
}
输出类似
的内容1731656333
1731656333
在我们看到相同的ActorSystem
被注入的情况下,同样的hashCode
也是如此。
说我们像这样删除@Singleton
提供程序
@Provides
def getActorSystem: ActorSystem = ActorSystem()
然后hashCode
个不同,例如,
2050462663
1117871068