Java 通常可以根据参数推断泛型(甚至根据返回类型,与例如 C# 相比)。
举个例子:我有一个通用类Pair<T1, T2>
,它只存储一对值,可以按以下方式使用:
Pair<String, String> pair = Pair.of("Hello", "World");
该方法of
如下所示:
public static <T1, T2> Pair<T1, T2> of(T1 first, T2 second) {
return new Pair<T1, T2>(first, second);
}
非常好。但是,这不再适用于以下需要通配符的用例:
Pair<Class<?>, String> pair = Pair.of((Class<?>) List.class, "hello");
(注意显式转换以List.class
生成正确的类型。)
代码失败并出现以下错误(由 Eclipse 提供):
类型不匹配:无法转换
TestClass.Pair<Class<capture#1-of ?>,String>
为TestClass.Pair<Class<?>,String>
但是,显式调用构造函数仍然可以按预期工作:
Pair<Class<?>, String> pair =
new Pair<Class<?>, String>((Class<?>) List.class, "hello");
有人可以解释这种行为吗?是设计使然吗?想要吗?我是在做错什么,还是偶然发现了编译器中的设计缺陷/错误?
疯狂的猜测:“捕获#1-of ?” 不知何故,似乎暗示通配符是由编译器动态填充的,使类型 a Class<List>
,因此转换失败(从Pair<Class<?>, String>
到Pair<Class<List>, String>
)。这是正确的吗?有没有办法解决这个问题?
为了完整起见,这里是Pair
该类的简化版本:
public final class Pair<T1, T2> {
public final T1 first;
public final T2 second;
public Pair(T1 first, T2 second) {
this.first = first;
this.second = second;
}
public static <T1, T2> Pair<T1, T2> of(T1 first, T2 second) {
return new Pair<T1, T2>(first, second);
}
}