[英]Guice: use the same instance independently and inside the binder
是否可以创建一个 singleton object,并能够将其作为一个实例独立注入,或者作为集合或 map 的一部分注入?
例如,我有两个这样的实例:
@Provides
@Singleton
@Named(value = "bike.listener")
fun bikeListener(
mapper: ObjectMapper,
amazonSNS: AmazonSNS,
kafkaPublisher: KafkaPublisher
): PublishingListener {
return PublishingListener(
mapper = mapper,
amazonSns = amazonSNS,
kafkaPublisher = kafkaPublisher
)
}
@Provides
@Singleton
@Named(value = "car.listener")
fun carListener(
mapper: ObjectMapper,
amazonSNS: AmazonSNS,
kafkaPublisher: KafkaPublisher
): PublishingListener {
return PublishingListener(
mapper = mapper,
amazonSns = amazonSNS,
kafkaPublisher = kafkaPublisher,
)
}
...我通过@Named
参数直接注入它们,在我的类中使用它们。 但是,我也有一个用例,我想将它们都注入一个集合中。
所以像:
@Inject
Set<PublishingListener> listeners; // carListener and bikeListener here
是否可以创建使用已定义实例的MultiBinder
? 如何在集合中单独使用相同的实例?
在您的 Guice 模块中,您可以将这些实例绑定到这样的集合:
@Provides
fun publisherListenerSet(
@Named("car.listener") val carListener: PublisherListener,
@Named("bike.listener") val bikeListener: PublisherListener
): Set<PublisherListener> {
setOf(carListener, bikeListener)
}
或者您可以使用:
protected override fun configure() {
val publishingListenerSetBinder = Multibinder.newSetBinder(binder(), PublisherListener::class.java)
publishingListenerSetBinder.addBinding().annotatedWith(Names.named("car.listener"))!!.to(PublishingListener::class.java)
publishingListenerSetBinder.addBinding().annotatedWith(Names.named("bike.listener"))!!.to(PublishingListener::class.java)
}
由于您实际上并未调用提供者方法,因此 Injector 可以保持提供者提供的事物的单例性。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.