在这种情况下,对Class< MyClass>进行未经检查的强制转换应该是安全的:
// This is okay because we're switching to a type with an unbounded wildcard -
// the behaviors of Class.newInstance and Class.cast are still safe.
@SuppressWarnings("unchecked")
Class> classWithNarrowedType =
(Class>)(Class>)MyClass.class;
populateMap(m, classWithNarrowedType);
这是一个非常重要的解决方案,特别是如果你有很多像这样的调用网站,但是没有解决类文字用原始类型参数化的事实,使它们被用作参数化类型的工厂,如MyClass< T>本质上很尴尬.
一个可能更清晰的解决方案是将populateMap与类文字的使用分离:
interface Parser {
T parse();
}
static void populateMap(Map map, Parser parser) { ... }
...
Map> m = new HashMap<>();
Parser> myClassParser = new Parser>() {
@Override
public MyClass> parse() {
return parse(..., MyClass.class);
}
};
populateMap(m, myClassParser);
static void populateMap(Map map, Parser parser)