so there must be another class implement A
不一定是真的.对于这种类型的递归边界,创建子类型时有两种可能的方式来满足约束.
>用相同或更多限制范围声明您自己的类型参数.这给选择此类用户的类型参数带来了负担.
public class TBaseImpl, B extends TFieldIdEnum> implements TBase
或更可能
public class TBaseImpl, B extends TFieldIdEnum> implements TBase
>通过与您定义的类相同的类来满足原始范围.
public class TBaseImpl implements TBase
这种模式的好处是能够限制方法的参数,而该方法的目的是采用同一类的另一个实例,例如:
public void example(T other)
通常,实现/覆盖方法必须完全匹配参数类型和参数顺序.但是这种模式允许您通过缩小type参数来缩小类型.例如.在这种情况下,TBaseImpl中的此类方法将仅采用TBaseImpl,而不会采用更广泛的T或TBase.在这样的类中,类与自身之间存在关系.
另一个好处是方法链接,其中方法将其返回以允许
obj.method1().method2().method3()
通过这种方式,可以声明链接方法以返回T,例如TBase< TBaseImpl>变量可以调用这些方法,每个方法都返回一个TBaseImpl,可以在其上调用另一个方法.
T method1(); // in TBase
@Override
TBaseImpl method1(); // in TBaseImpl
顺便说一句,如果您试图声明一个类型变量,该类型变量是枚举的子类型,则没有必要,因为枚举是最终的并且不能扩展.删除接口中的F并让实现类直接使用枚举会更简单.