Właśnie zapoznałem się z kolejkami priorytetowymi i pomyślałem, że spróbuję, jak zachowuje się przy porównywalnym interfejsie.Kolejki priorytetów Java i porównywalny interfejs
Code Snippet:
import java.util.PriorityQueue;
class kinga implements Comparable<Double> {
double time=909.909;
double d;
public kinga(double a) {
this.d=a;
}
public int compareTo(Double d) {
return Double.compare(d, time);
}
public static void main(String arg[]) {
PriorityQueue<kinga> r=new PriorityQueue<kinga>();
r.add(new kinga(4545.45));
r.add(new kinga(45.4));
r.add(new kinga(1235.45));
System.out.println(r.poll()+" "+r.poll()+" "+r.poll());
}
}
To kompiluje ale daje mi wyjątek w wątek "głównym"java.lang.ClassCastException: kinga cannot be cast to java.lang.Double
.
Co jest nie tak? Czy ktoś może mi powiedzieć, jak działają porównywalne i priorytetowe kolejki?
zobacz moją odpowiedź na edytowany kod i wynik dla tego samego. –