我正在使用guice进行依赖项注入,并编写了一个提供程序,该提供程序返回HashMap< String,HashMap< String,String>>.如何将HashMap.class与此提供程序绑定?
我查看了this,但无法弄清楚如何将TypeLiteral用于HashMap< K,V>中的HashMap值(V).因此,我只是在< K,V>中替换了V.与对象.目前,我的丑陋绑定看起来像下面这样,它有明显的缺点.我必须获取对象并将其转换为HashMap< String,String>才能获取更多值.但这有效,但我正在寻找更好的建议.
binder().bind(new TypeLiteral<Map<String, Object>>() {}).toProvider(
(Class<? extends Provider<? extends Map<String, Object>>>) TestProvider.class);
解决方法:
类型文字可以在两个层次上指定其泛型,也可以根据需要进行指定.尝试这个.
class TestProvider implements Provider<Map<String, Map<String, String>>> {
@Override public Map<String, Map<String, String>> get() {
// If you had Guava, you could just call "return Maps.newHashMap();".
// On Java 7, you can use "return new HashMap<>();".
return new HashMap<String, Map<String, String>>();
}
}
class TestModule extends AbstractModule {
@Override protected void configure() {
bind(new TypeLiteral<Map<String, Map<String, String>>>() {})
.toProvider(TestProvider.class);
// or
bind(new TypeLiteral<HashMap<String, HashMap<String, String>>>() {})
.toProvider(HashMapTestProvider.class);
}
}
>支持接口而非实现,请注意:
HashMap<String, HashMap<String, String>>
can be cast to Map<String, HashMap<String, String>> (1)
but cannot be cast to Map<String, Map<String, String>> (2)
上面的(1)保证它只包含HashMap,而(2)可以包含任何地图实现.
>您可能会喜欢直接使用Guava Table
.它基本上是一个两键映射,可以根据需要为您创建行或列映射.