自绑定generics类型,具有流畅的接口和inheritance

我使用流畅的inheritance接口。 我声明基类Constructor受到保护,所以你不能创建一个Foo ,它会在调用add()时导致ClassCastException。 但我遇到了返回新Foo实例的静态方法的问题。

public class Foo<T extends Foo> // if i change to extends Foo i only get warnings { public static Foo createFoo() // <-- error { return new Foo(); // <-- error } protected Foo() {} public T add() { //... return (T)this; } } public class Bar extends Foo { public Bar sub() { //... return this; } } 

这主要是Fluent Interfaces,Domain-specific language和Generics中的练习(个人而非家庭作业),所以请不要问我需要它。

编辑:Eclipse错误

 Bound mismatch: The type Foo is not a valid substitute for the bounded parameter <T extends Foo> of the type Foo 

你基本上有一个递归类型声明。

Foo>

所以假设你有一个Foo 。 这意味着T被映射到Foo 。 但是Foo不是Foo子类型,在这种情况下是Foo ,所以你真正想要的是Foo> 。 但是等一下,最里面的Foo没有输入,所以我猜它是Foo>> …哦,忘了!

为了让它更容易理解,考虑一下你是否有Foo> 。 在Foo的声明/实例化中你可以用什么来做TListList

编辑

看起来你找到了一种“打破”递归周期的方法。 你最终需要得到一个具体的类型。 就像你发现ConcreteFoo为你工作的方式一样,你可以类似地对上面的List例子中有一些类ConreteListOfItself implements List ,它会破坏递归周期。