filter.put("a", EnumA.class);I got following setup:
public interface InterfaceA {
abstract public Object[] foo();
}
public enum EnumA implements InterfaceA {
RED();
...
}
public enum EnumB implements InterfaceA {
OAK();
...
}
现在我想使用这个构造typesave,我得到了这个:
private <T extends Enum<T> & InterfaceA> void importSettingViaEnum(Class<T> clazz) { ...
for (T elem : clazz.getEnumConstants()){
... = f(elem.ordinal());
... = elem.foo();
...
}
}
这似乎是正确的,clazz应该只在上面的枚举工作。但现在,我无法弄清楚这张地图的正确类型,这是行不通的:
public <T extends Enum<T> & InterfaceA> Main() {
Map<String, Class<T>> filter = new HashMap<>();
filter.put("a", EnumA.class);
filter.put("b", EnumB.class);
importSettingViaEnum(filter.get("a"));
}
有人有线索吗?我希望这个东西是安全的。
这里有一些pastebin:https://pastebin.com/fKxtBGBe
编辑1:
尝试过这样的事情,但它没有工作......
public Main() {
Map<String, Class<? extends Enum<? extends InterfaceA>>> filter = new HashMap<>();
filter.put("a", EnumA.class);
filter.put("b", EnumB.class);
importSettingViaEnum(filter.get("a")); // BREAK THE BUILD
}
答案 0 :(得分:3)
类型擦除...提供泛型类型参数的类型对象。
public <T extends Enum<T> & InterfaceA> void main(Class<T> type) {
Map<String, Class<T>> filter = new HashMap<>();
filter.put("a", type);
//importSettingViaEnum(filter.get("a"));
}
main(EnumA.class);
这也解耦了实现类型(EnumA)。
或者选择部分类型安全
public void main2() {
Map<String, Class<? extends InterfaceA>> filter = new HashMap<>();
filter.put("a", EnumA.class);
Class<? extends InterfaceA> type = filter.get("a");
if (type.isEnum()) {
....
}
}
如果需要,将类型转换为枚举。
答案 1 :(得分:0)
如果你想为一个类创建一个sting的地图,这应该适合你:
Map<String, Class> filter = new HashMap<>(); // any Class put against a string in the map
filter.put("a", EnumA.class);