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

前端之家收集整理的这篇文章主要介绍了java – 为什么泛型类型具有相同的签名?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有以下泛型类:
  1. class Or<A,B>
  2. {
  3. Or (A a) {}
  4. Or (B b) {}
  5. }

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

  1. Or(A) is already defined in Or
  2. Or (B b)
  3. ^

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

更新

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

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

解决方法

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

他们是这样.签名是

  1. Or(Object o);

Why?

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

And how to work around this problem?

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

  1. // Hide the constructor
  2. private Or(...) {
  3. ...
  4. }
  5. // Publish factory methods
  6. public static <X> Or OrWithA(X a) {
  7. return new Or(...);
  8. }
  9. public static <X> Or OrWithB(X a) {
  10. return new Or(...);
  11. }

猜你在找的Java相关文章