在这种情况下,它应该是安全的做一个未经检查的强制转换为Class>:
// 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固有的尴尬。
一个潜在的清洁解决方案会因使用类文字的脱钩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)