Я только что узнал о очередях приоритетов и подумал, что попробую, как он ведет себя с сопоставимым интерфейсом.Очереди приоритетов Java и сопоставимый интерфейс
Код сниппета:
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());
}
}
Он компилирует, но дает мне исключение в нить "основной"java.lang.ClassCastException: kinga cannot be cast to java.lang.Double
.
Что здесь не так. Может ли кто-нибудь сказать мне, как работают сопоставимые очереди и очереди приоритетов?
см. Мой ответ для отредактированного кода и вывода для него. –