我有一个类Zeitpunkt,它实现了一个带时间的日期,另外还有一个类Suchbaum,它代表一个二叉搜索树。
我想在Suchbaum中使用Comparator-Object在Zeitpunkt之前对树进行排序,但是当我想创建一个Suchbaum对象时,它会打印出命名错误。
Zeipunkt
public class Zeitpunkt<T> implements Comparable<T>
{
private int jahr;
private int monat;
private int tag;
private int stunden;
private int minuten;
private double sekunden;
public int vergleich(Zeitpunkt a) { ... }
@Override
public int compareTo(T o) {
if(o instanceof Zeitpunkt)
return vergleich((Zeitpunkt)o);
return 0;
}
...
}
Suchbaum
public class Suchbaum<T extends Comparable<T>> {
private class Element {
private T daten;
private Element links;
private Element rechts;
public Element(T t) {
daten = t;
links = null;
rechts = null;
}
}
private Element wurzel;
private Comparator<T> comp;
...
}
识别TestClass
public class BaumTest {
public static void main(String[] args) {
// error in the following line (IntelliJ underlines the first
// "Zeitpunkt"). Suchbaum<Zeitpunkt<?>> = ... doesn't work either..
// *Completely confused*
Suchbaum<Zeitpunkt> sb = new Suchbaum<>((Zeitpunkt z1, Zeitpunkt z2) -> {
if(z1.getTag() > z2.getTag())
return 1;
else if(z1.getTag() == z2.getTag())
return 0;
else
return -1;
});
}
}
有什么想法吗? (这个主题的其他主题并没有帮助我)
答案 0 :(得分:3)
似乎您不希望将Zeitpunkt
类设置为参数化,您只是希望它实现Comparable
接口。所以改变它:
public class Zeitpunkt implements Comparable<Zeitpunkt> {
private int jahr;
private int monat;
private int tag;
private int stunden;
private int minuten;
private double sekunden;
public int vergleich(Zeitpunkt a) {
return 0;
}
@Override
public int compareTo(Zeitpunkt o) {
return vergleich(o);
}
}
您还需要在Suchbaum
类中定义构造函数:
public Suchbaum(Comparator<T> comp) {
this.comp = comp;
}