有没有办法绑定下一种类型的泛型类型:
public interface A<T extends Number> {
void print(T t);
}
public class B implements A<Integer> {
@Override
public void print(Integer i) {
System.out.println(i);
}
}
public class C implements A<Double> {
@Override
public void print(Double d) {
System.out.println(d);
}
}
如何完全绑定上述接口及其实现(使用TypeLiteral
?),以便我可以通过某种条件创建一个类型化实例?
class Main {
public static void main(String[] args) {
A a1 = Guice.createInjector(new MyModule()).getInstance( ??? );
a1.print(1); //will print 1
A a2 = Guice.createInjector(new MyModule()).getInstance( ??? );
a2.print(1.0); //will print 1.0
}
}
MyModule
如何看起来像?
答案 0 :(得分:3)
你缺少的是,
Injector injector = Guice.createInjector(new MyModule());
A a1 = injector.getInstance(Key.get(new TypeLiteral<A<Integer>>() {}));
和你的MyModule
public static class MyModule extends AbstractModule {
@Override
protected void configure() {
bind(new TypeLiteral<A<Integer>>() {}).toInstance(new B());
}
}
答案 1 :(得分:3)
您可以创建提供程序方法,而无需在定义中使用TypeLiteral<A<Integer>>
。
class MyModule extends AbstractModule {
@Provides
@Singleton
A<Integer> provideAOfInteger() {
return new B();
}
}
您还可以使用隐式绑定来访问A<Integer>
:
class AOfIntegerHolder {
@Inject A<Integer> aOfInteger;
}
Injector injector = Guice.createInjector(new MyModule());
A<Integer> a1 = injector.getInstance(AOfIntegerHolder.class).aOfInteger;
Guice的美妙之处在于,通常有多种方法可以做你想做的事情,而且没有一种比另一种更好:它们只是不同;)