java – 为什么泛型类型具有相同的签名?

我有以下泛型类:
class Or<A,B>
{
  Or (A a) {}
  Or (B b) {}
}

我尝试编译时为什么会出现以下错误

Or(A) is already defined in Or
    Or (B b)
    ^

在我看来,两个构造函数共享相同的签名,尽管它们具有不同的泛型类型参数.为什么?以及如何解决这个问题?

更新

我现在明白了这个问题.编译器需要一种方法来区分这两种类型.添加这样的约束对我的用例来说是可以的.所以我想补充一个问题:

如何指定A和B这两种类型可能是不同的?

解决方法

It seems to me that the two constructors share the same signature although they have different generic type arguments.

他们是这样.签名是

Or(Object o);

Why?

由于Java中7000泛型的实现:对泛型类型的引用在使用它们的所有上下文中都被转换为System.Object;泛型类型只有编译器知道.

And how to work around this problem?

不幸的是,您无法在构造函数中轻松解决此问题.您可以使用工厂方法替换重载的构造函数,并提供不同的名称,例如OrWithA和OrWithB:

// Hide the constructor
private Or(...) {
    ...
}
// Publish factory methods
public static <X> Or OrWithA(X a) {
    return new Or(...);
}
public static <X> Or OrWithB(X a) {
    return new Or(...);
}

相关文章

最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤...
/*HashSet 基本操作 * --set:元素是无序的,存入和取出顺序不...
/*list 基本操作 * * List a=new List(); * 增 * a.add(inde...
/* * 内部类 * */ 1 class OutClass{ 2 //定义外部类的成员变...
集合的操作Iterator、Collection、Set和HashSet关系Iterator...
接口中常量的修饰关键字:public,static,final(常量)函数...