[英]Guice instance binding for generic type
我希望我的模块将Parent的子类绑定到我创建的实例。
public class MyModule<T extends Parent> implements AbstractModule {
T myAwesomeInstance;
MyModule(String[] args, Class<T extends Parent> clazz) {
myAwesomeInstance = clazz.newInstance(); // catching exceptions and stuff ...
ArgumentParser.configure(myAwesomeInstance, args);
}
@Override
void configure() {
bind(new TypeLiteral<T>(){}).toInstance(myAwesomeInstance);
}
}
这段代码可以很好地编译,但是当我尝试运行时,Guice会抱怨“ T不能用作键;它没有完全指定”。 如何将泛型类绑定到模块创建的该类的实例?
我的解决方案与建议的副本不同。 我需要保存类对象,以便将类正确绑定到我选择的实例。
public class MyModule<T extends Parent> implements AbstractModule {
T myAwesomeInstance;
Class<T> _clazz;
MyModule(String[] args, Class<T extends Parent> clazz) {
myAwesomeInstance = clazz.newInstance(); // catching exceptions and stuff ...
_clazz = clazz;
ArgumentParser.configure(myAwesomeInstance, args);
}
@Override
void configure() {
bind(TypeLiteral.get(_clazz)).toInstance(myAwesomeInstance);
}
}
无需使用TypeLiteral
,您可以直接使用Key
。 (这使您有机会根据需要添加注释。)
最好将构造实例推迟到单例时间,而不是将模块实例化。 例如,您可以这样做:
public final class MyModule<T extends Parent> extends AbstractModule {
private final Key<T> key;
private final Provider<T> provider;
public MyModule(final Class<T> clazz, final String[] args) {
this.key = Key.get(clazz); // Or add an annotation if you feel like it
this.provider = new Provider<T>() {
@Override public T get() {
try {
T instance = clazz.newInstance();
// etc.
} catch (ReflectiveOperationException ex) {
// throw a RuntimeException here
}
}
};
}
@Override protected void configure() {
bind(key).toProvider(provider).in(Singleton.class);
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.