- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
以下通用 Guice 绑定(bind)方法行为正确:
<T> Key<?> bindMultibinder(
ArrayList<Class<? extends T>> contents, Class<T> superClass) {
Named annotation = randomAnnotation();
Multibinder<T> options =
Multibinder.newSetBinder(binder(), superClass, annotation);
for (Class<? extends T> t : contents) {
options.addBinding().to(t);
}
final Key<?> multibinderKey = Key.get(Types.setOf( superClass ), annotation);
return multibinderKey;
}
并像这样使用客户端代码:
ArrayList<Class<? extends Option>> options =
new ArrayList<Class<? extends Option>>();
options.add(CruiseControl.class);
bindMultibinder(options, Option.class);
但是,如果我想允许Option
采用像 Option<Radio>
这样的通用参数,然后我假设我需要传递 TypeLiteral
在bindMultibinder
父类(super class)参数。这是我迄今为止最好的尝试:
<T> Key<?> bindMultibinder(
ArrayList<TypeLiteral<? extends T>> contents, TypeLiteral<T> superClass) {
Named annotation = randomAnnotation();
Multibinder<T> options =
Multibinder.newSetBinder(binder(), superClass, annotation);
for (TypeLiteral<? extends T> t : contents) {
options.addBinding().to(t);
}
final Key<?> multibinderKey = Key.get(Types.setOf(superClass.getRawType()), annotation);
return multibinderKey;
}
与前一种情况等效的绑定(bind)代码如下所示:
ArrayList<TypeLiteral<? extends Option>> options =
new ArrayList<TypeLiteral<? extends Option>>();
options.add(new TypeLiteral<CruiseControl>(){});
bindMultibinder(options, new TypeLiteral<Option>(){});
我几乎可以肯定下面的绑定(bind)是不正确的,因为 Types.setOf(superClass.getRawType())
返回 ParameterizedType
final Key<?> multibinderKey =
Key.get(Types.setOf(superClass.getRawType()), annotation);
关于如何正确创建集的任何想法?
最佳答案
ParameterizedType
是 java 类,用于表示在 java 源代码中您需要用尖括号编写的类型:类似 Foo<Bar>
的类型或 Set<Option>
或 Set<Option<Radio>>
甚至 Set<? extends Option<Radio>>
.这就是你想要的返回值。
您所做的实际上将与您想要调用的非常小的更改一起正常工作 superClass.getType()
在倒数第二行而不是 superClass.getRawType()
.话虽这么说,但我在这里还有一些其他建议。
首先,在您的第一种方法中,我将其更改为:
<T> Key<Set<T>> bindMultibinder(
Iterable<? extends Class<? extends T>> contents, Class<T> superClass) {
Named annotation = randomAnnotation();
Multibinder<T> options =
Multibinder.newSetBinder(binder(), superClass, annotation);
for (Class<? extends T> t : contents) {
options.addBinding().to(t);
}
@SuppressWarnings("unchecked")
final Key<Set<T>> multibinderKey = (Key<Set<T>>) Key.get(Types.setOf( superClass ), annotation);
return multibinderKey;
}
这会让你像这样调用:
bindMultibinder(ImmutableList.of(CruiseControlSubOptOne.class,
CruiseControlSubOptTwo.class),
Option.class);
或者,如果您不使用 guava - 虽然你应该 - 你可以使用 Arrays.asList
而不是 ImmutableList.of
.您可以获得与以前相同的类型安全性,而无需在绑定(bind)代码中声明所有这些尖括号。
如果 bindMultibinder
的来电者不多然而,我也会交换参数的顺序,但这可能只是个人风格问题。
通过这些相同的更改,您的第二种方法变为:
<T> Key<Set<T>> bindMultibinder(
Iterable<? extends TypeLiteral<? extends T>> contents, TypeLiteral<T> superClass) {
Named annotation = randomAnnotation();
Multibinder<T> options =
Multibinder.newSetBinder(binder(), superClass, annotation);
for (TypeLiteral<? extends T> t : contents) {
options.addBinding().to(t);
}
@SuppressWarnings("unchecked")
final Key<Set<T>> multibinderKey = (Key<Set<T>>) Key.get(Types.setOf(superClass.getType()), annotation);
return multibinderKey;
}
你可以类似地使用它:
bindMultibinder(ImmutableList.of(
new TypeLiteral<CruiseControlSubOptOne>() {},
new TypeLiteral<CruiseControlSubOptTwo>() {}),
new TypeLiteral<Option>() {});
尽管现在想想,我想知道你是否真的想要重载 bindMultibinder
这需要 TypeLiteral
.你不想拥有一个需要 Key
的人吗?相反?
<T> Key<Set<T>> bindMultibinder(Iterable<? extends Key<? extends T>> contents, Key<T> superClass) {
Named annotation = randomAnnotation();
Multibinder<T> options =
Multibinder.newSetBinder(binder(), superClass.getTypeLiteral(), annotation);
for (Key<? extends T> t : contents) {
options.addBinding().to(t);
}
@SuppressWarnings("unchecked")
final Key<Set<T>> multibinderKey =
(Key<Set<T>>) Key.get(Types.setOf(superClass.getTypeLiteral().getType()), annotation);
return multibinderKey;
}
毕竟,您可以用几乎相同的方式调用此方法:
bindMultibinder(ImmutableList.of(
new Key<CruiseControlSubOptOne>() {},
new Key<CruiseControlSubOptTwo>() {}),
new Key<Option>() {});
除了Key
比 TypeLiteral
更容易输入,并且如果您需要放入仅由其注释标识的内容,那将是微不足道的:
bindMultibinder(ImmutableList.of(
new Key<CruiseControlSubOptOne>() {},
new Key<CruiseControlSubOptTwo>() {},
Key.get(CruiseControl.class, Names.named("ThirdOpt")),
Key.get(CruiseControl.class, Names.named("FourthOpt"))),
new Key<Option>() {});
现在,是@Suppress
让你紧张?良好的直觉。
不幸的是,可悲的事实是,在处理泛型类型周围的反射时(其中带有尖括号的类型),您几乎肯定会有一些未检查的小位。我的建议是让需要抑制非类型化警告的部分尽可能小,并尽可能多地向外界公开类型信息。如果您返回 Key<?>
从这里开始,您可能会让此方法的调用者在尝试使用您的返回值时抑制未类型化警告。最好在此处执行此操作,您可以将警告抑制限制在一行,并且可以证明转换是安全的。
关于java - 这个通用 Guice 绑定(bind)方法的 TypeLiteral 等价物有什么问题?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8683652/
我有很多 TabularResultSet 类的带注释的命名实例,我想将它们传递给多个类并传递给静态最终属性。我该如何注入(inject)?我认为它不喜欢该属性的最终和静态性质。必须在属性声明中直接调
我是 Guice 的新手,我想知道我能走多远。 我有一个接口(interface)UserInfo具有多个实现类 GoogleUserInfo , FacebookUserInfo , Twitter
我的应用程序中绑定(bind)了两个类型的命名实例: bind(Foo.class).toProvider(FooProvider.class); bind(Foo.class).annotatedW
我有一个 Guice 模块,它有一个 @Provides 方法,它接受 2 个参数并返回接口(interface)的实现: public class **ClientModule** extends
请解释在以下使用工厂的场景中使用 Google-Guice 自动连接的正确方法。我正在使用 XML 工厂进行 XSLT 处理。 StringWriter strWriter = new StringW
我有一个 Guice Module提供 List使用 @Provides - 带注释的方法。 class TestModule() : Module { override fun configur
为什么Guice 3.0针对错误的配置组件(例如,缺少@Inject)抛出此异常,而不是格式化消息? Exception in thread "main" com.google.inject.inte
我有以下供应商: public class GuiceResourceProvider implements Provider { @Inject private Configur
使用 Guice-servlet,我们可以轻松地进行 servlet 映射,如下所示: filter(*.jsp).through(MyFilter.class) 但是,谁能告诉我如何将过滤器映射到
我正在尝试向我的项目添加 Swagger 。我们的设置与示例项目略有不同。我们使用 guice 和 guice-servlet 来注入(inject)并启动我们的 JerseyServletModul
假设我有一个 Guice 模块 ProdModule,我想依赖其他 GuiceModule、ProdDbModule 和 ProdPubSubModule。我将如何实现 ProdModule 的 co
我正在考虑在我的应用程序中使用 Guice for DI,我应该能够在运行时交换实现。下面提供了一个示例来说明要求: class ValidationEngine { public void v
我想设置 Guice 绑定(bind),所以我用 Java 创建了一个完美运行的模块: public class CrashLoggerModule extends AbstractModule {
所以我有一个模块将接口(interface)与实现类绑定(bind)。 bind(ILocalStore.class).to(LocalStore.class); 此绑定(bind)是否还会注入(in
guice 4.0 是否向后兼容 3.x?无法从发行说明或常见问题解答中弄清楚... 如果没有,是否有兼容性问题列表? 最佳答案 我没有任何官方来源但根据我的经验,没有任何兼容性问题。 我使用了几个
我正在尝试使用 Guice,并且我来自 Spring。 我想知道 @Inject 是否相当于 Spring 中的 @Autowired 以及我是否可以在 Web 应用程序中使用它,就像在 Spring
我是 Guice DI 的新手。我想弄清楚我的情况。 简单来说,有没有通过Guice @annotations来替代MapBinder的? 我的场景: Interface A{} Class A1 i
我的项目正在使用 Guice作为负责为大型对象图(主要是单例)提供依赖项(服务类)的 IOC 容器。有时,如果在构造过程中依赖项失败,并且许多对象都需要此依赖项,则失败将一遍又一遍地发生,并将异常添加
我有一个类 (CustomConnectionProvider),它将由第三方库 (hibernate) 使用 class.forName().newInstance() 实例化。我需要注入(inje
删除 guice servlet 后,我需要进行一些清理。使用 guice servlet 时是否可以 Hook 到 servlet 破坏?我需要使用喷油器进行清理工作。 我可以覆盖 contex
我是一名优秀的程序员,十分优秀!