通用边界“Enum<T> & Foo”和“Enum<之间有区别吗?扩展 Foo>”
以下两个(有效的)泛型边界是:
<T extends Enum<T> & MyInterface>
<T extends Enum<? extends MyInterface>>
一样?
假设我有一个接口
interface MyInterface {
void someMethod();
}
以及实现它的一些枚举:
enum MyEnumA implements MyInterface {
A, B, C;
public void someMethod() {}
}
enum MyEnumB implements MyInterface {
X, Y, Z;
public void someMethod() {}
}
我想要求一个实现不仅使用 a,而且还要求它是一个枚举。“标准”方式是通过交叉绑定:MyInterface
static class MyIntersectionClass<T extends Enum<T> & MyInterface> {
void use(T t) {}
}
但我发现这也有效:
static class MyWildcardClass<T extends Enum<? extends MyInterface>> {
void use(T t) {}
}
通过上述内容,这将编译:
public static void main(String[] args) throws Exception {
MyIntersectionClass<MyEnumA> a = new MyIntersectionClass<MyEnumA>();
a.use(MyEnumA.A);
MyWildcardClass<MyEnumB> b = new MyWildcardClass<MyEnumB>();
b.use(MyEnumB.X);
}
对于这两种情况,绑定的工作方式与上述内容的预期和要求相同。
这两个边界之间是否有区别,如果是这样,那么一个边界是否比另一个“更好”?