Java-priority-queues und vergleichbare Schnittstelle

Ich habe gerade das lernen über priority-queues und dachte, ich würde versuchen, wie verhält es sich mit vergleichbaren Schnittstelle.

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());
    }
}

Es kompiliert, aber der gibt mir Ausnahme in thread "main" java.lang.ClassCastException: kinga cannot be cast to java.lang.Double.

Was ist hier falsch. Kann jemand mir sagen, wie vergleichbar und priority-queues arbeiten?

  • siehe meine Antwort für den bearbeiteten code und die Ausgabe für den gleichen.
InformationsquelleAutor JohnnyHunter | 2013-08-21
Schreibe einen Kommentar