嗨,我对Java缺乏经验。我理解继承的概念,但我认为语法是在逃避我。我正在寻求一些帮助,让我开始扩展这个抽象类: 我需要从中创建一个具体的对象。
这个类应该做的是在初始化期间输入一个类型并存储该类型的对象列表。对它们进行排序,然后在调用showTopN时返回n个顶级对象的列表。
我还没有开始实现逻辑。
abstract class Foo<T extends Comparable<T>> {
int n;
Foo(int n){ // constructor; sets object property n
this.n = n;
}
abstract void push(T object); //object method to store a new object in the list
abstract List<T> showTopN(); // object method to return top n entries in the list, sorted.
}
我试图通过这种方式将其扩展为具体对象:
class ConcreteFoo extends Foo {
private List<Foo> fooList;
public void push(Foo object) {
}
@Override
public List<Foo> showTopN() {
return fooList;
}
@Override
public int compareTo(ConcreteFoo other) {
return 0;
}
}
但编译器抱怨我没有覆盖push方法。 有什么问题?
答案 0 :(得分:2)
这里有两件事。一个是&#34;抽象性&#34; Foo,但另一个是泛型。你忽略了泛型方面。
如果您知道Concrete foo关心的对象类型,您可以使用它:
class ConcreteFoo extends Foo<SomeKnownClass> {
private List<SomeKnownClass> list = new ArrayList<SomeKnownClass>();
void push(SomeKnownClass skc) {}
List<SomeKnownClass> showTopN() { return list; }
}
现在,如果您不知道 知道它的类型,您仍然可以使用泛型:
class ConcreteFoo<T extends Comparable<T>> extends Foo<T> {
private List<T> list = new ArrayList<T>();
void push(T skc) {}
List<T> showTopN() { return list; }
}
请注意,Foo
和ConcreteFoo
都不会实现可比较,因此您不需要compareTo
方法。
答案 1 :(得分:0)
push方法指定它将接受T
对象,这是Foo
的通用类型,您尚未声明。如果您希望Foo
成为自己的List
,我不确定您这样做,那么您必须将其声明为
class ConcreteFoo extends Foo<Foo> {
但我认为你需要重新审视自己的基本原则。
答案 2 :(得分:0)
您将容器与其包含的对象混为一谈。您想要的类结构类似于:
class Foo implements Comparable<Foo> { ... }
abstract class GenericContainer<T> {
abstract void push(T object); //object method to store a new object in the list
abstract List<T> showTopN(); // object method to return top k entries in the list, sorted.
}
class FooContainer extends GenericContainer<Foo> {
private List<Foo> fooList;
...
}
您的showTopN方法可以是:
public List<Foo> showTopN() {
return Collections.sort(fooList).subList(0, n);
}