PriorityQueue mit Objekten

Shizmo

Aktives Mitglied
Hallo ich würde gerne Objekte in eine Priority Queue geben und diese soll sie nach Werten des Objekts sortieren.

Also beispielsweise
Java:
Test x = new Test(12); 
Test y = new Test(5);

// x.getId(); <--- Diese Werte sollen verglichen werden

PriorityQueue <Test> queue = new PriorityQueue<>();
queue.offer(x);
queue.offer(y);

Ist sowas möglich?
 

Shizmo

Aktives Mitglied
So in der Richtung? Funktioniert leider nicht, also Objekte kann ich nun einfügen in die Queue, aber der Vergleich stimmt nicht (es wird nicht richtig sortiert).
Java:
public class Test implements Comparable<Test>{
        private int value;
       
        public Test(int value){
            this.value = value;
        }
       
        public int getValue(){
            return value;
        }

        @Override
        public int compareTo(Test o) {
            return Test.getValue();
        }
 

mrBrown

Super-Moderator
Mitarbeiter
Java:
@Override
public int compareTo(Test o) {
       return Test.getValue();
}

Ist auch ein ziemlich Sinnloses vergleichen ;)
Es sollten schon irgendwie beide Werte verglichen werden, so ist der Vergleich mehr oder weniger zufällig (und widerspricht dem JavaDoc)

Zum Vergleichen von ints mal in Integer gucken ;)
 

Shizmo

Aktives Mitglied
Ich verstehs nicht.

Mit welchem Wert soll ich vergleichen? Mit der Instanzvariable value?
Warum Integer, wenn ich int habe?
 

mrBrown

Super-Moderator
Mitarbeiter
Du musst in compare den aktuellen Test mit dem übergebenen Test vergleichen.
Was da verglichen wird, musst du überlegene, das kommt drauf an, welche natürliche Ordnung dein Test haben soll.
Bei diesen wird sinnvollerweise verglichen, indem value verglichen wird (da es die einzige Instanzvariable ist).

Integer stellt Methoden für ints bereit, ua um diese zu vergleichen.
 

Shizmo

Aktives Mitglied
Okay, also meinst du so:

Java:
@Override
        public int compareTo(tes o) {
            return Integer.valueOf(value).compareTo(Integer.valueOf(o.getValue()));
        }

Jetzt ist die Reihenfolge verändert, aber nicht so wie es sein soll.
Eingabe 5 - 8 -3
Ausgabe 3 - 8 - 5

Hmmm... :(
 

mrBrown

Super-Moderator
Mitarbeiter
Kürzer wäre
Code:
@Override
        public int compareTo(Test that) {
            return Integer.compare(this.value,that.value);
        }

Zeig mal deinen Code, vllt liegt da woanders noch ein Fehler
 

Shizmo

Aktives Mitglied
Einmal Test-Klasse:
Java:
import java.util.*;

public class Test implements Comparable<Test>{
        private int value;
       
        public Test(int value){
            this.value = value;
        }
       
        public int getValue(){
            return value;
        }

        @Override
        public int compareTo(Test o) {
            return Integer.compare(this.value, o.getValue());
        }
       
        @Override
        public String toString(){
            return ""+value;
        }
    }

Und die Main zum Testen:
Java:
import java.util.*;

public class Main{
    
    public static void main(String[] args){
       
        Test x = new Test(5);
        Test y = new Test(8);
        Test z = new Test(3);
       

        PriorityQueue <Test> queue = new PriorityQueue<>();
       
        queue.offer(x);
        queue.offer(y);
        queue.offer(z);
              

        System.out.println(queue);
    }
}
 

mrBrown

Super-Moderator
Mitarbeiter
Du musst auch #peek oder #poll benutzen, um das jeweils kleinste zu bekommen ;)

#toString berücksichtigt nicht die Sortierung
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
X Probleme im Umgang mit PriorityQueue Java Basics - Anfänger-Themen 75
M Getter einer PriorityQueue Java Basics - Anfänger-Themen 1
U PriorityQueue remove Java Basics - Anfänger-Themen 2
U PriorityQueue initial capacity Java Basics - Anfänger-Themen 3
SheldoN Sortieren in PriorityQueue Java Basics - Anfänger-Themen 6
P PriorityQueue mit Einfügereihenfolge Java Basics - Anfänger-Themen 6
B PriorityQueue im dijkstra Algorithmus implementieren Java Basics - Anfänger-Themen 4
G Datentypen PriorityQueue und Map Java Basics - Anfänger-Themen 4
S PriorityQueue? Java Basics - Anfänger-Themen 2
H Membervariablen für PriorityQueue vergleichen? Java Basics - Anfänger-Themen 7
R PriorityQueue Java Basics - Anfänger-Themen 3
D Array List mit Objekten sortieren Java Basics - Anfänger-Themen 2
T Kollision von 2 Objekten Java Basics - Anfänger-Themen 2
T Variable von Objekten in einer Methode überprüfen Java Basics - Anfänger-Themen 26
B Reflection ändern von Objekten in Objekten Java Basics - Anfänger-Themen 12
H Kompliziertes Sortieren einer ArrayList mit Objekten(Sortieren nach X und Y) Java Basics - Anfänger-Themen 11
T Permanentes speichern von Objekten in einer ArrayList Java Basics - Anfänger-Themen 6
N Vererbung Queue bestehend aus Superclass- und Subclass-Objekten Java Basics - Anfänger-Themen 7
B Compiler-Fehler Array aus Objekten übergeben Java Basics - Anfänger-Themen 7
YAZZ Schlüsselworte Töten von Objekten Gameover Java Basics - Anfänger-Themen 2
F Abstand zwischen zwei Objekten berechnen wie? Java Basics - Anfänger-Themen 1
districon Vergleichen von Objekten Java Basics - Anfänger-Themen 20
Zeppi OOP Array in Objekten Java Basics - Anfänger-Themen 4
LetsSebi Methode, die einen arry von objekten speichert in einer datei Java Basics - Anfänger-Themen 6
JavaNoobi Try and Catch und übergabe von Objekten Java Basics - Anfänger-Themen 2
A Klasse Menge mit Objekten der Klasse Person Java Basics - Anfänger-Themen 8
S Auf Array aus Objekten zugreifen? Java Basics - Anfänger-Themen 1
D Mit Objekten rechnen, Textfield, JavaFX, Noob Java Basics - Anfänger-Themen 8
N enum Attribut von Objekten einer Hashmap ausgeben Java Basics - Anfänger-Themen 6
A Auf Eigenschaften von Objekten anderer Klassen zugreifen Java Basics - Anfänger-Themen 5
G Problem beim Speichern von Objekten in einer Datei Java Basics - Anfänger-Themen 7
N Klassen Rekursion mit Feldern von Objekten Java Basics - Anfänger-Themen 14
D Operatoren Mit Objekten rechnen Java Basics - Anfänger-Themen 7
E Datentypen Einfügen von Objekten in eine Map Java Basics - Anfänger-Themen 2
S Pane nach speziellen Child Objekten durchsuchen Java Basics - Anfänger-Themen 3
B ID von unterschiedlichen Objekten bekommen? Java Basics - Anfänger-Themen 2
T Daten von Objekten speichern Java Basics - Anfänger-Themen 7
PaperHat Programmieraufgabe - Objekte in Objekten Java Basics - Anfänger-Themen 2
L Rechnen mit Objekten Java Basics - Anfänger-Themen 3
S werte von objekten in schleife verändern Java Basics - Anfänger-Themen 14
D Zusammenarbeit von Objekten Java Basics - Anfänger-Themen 1
Y Begrenzte Anzahl an Objekten? Java Basics - Anfänger-Themen 12
Kornblume Nulltyp eines Arrays von Objekten? Java Basics - Anfänger-Themen 10
A Frage zur Aufgabe Uhrzeit einstellen mit Objekten Java Basics - Anfänger-Themen 18
M Generische Liste aus Comparable-Objekten Java Basics - Anfänger-Themen 6
G Klassen Call by Value auch bei Objekten? Java Basics - Anfänger-Themen 2
R Verständnisfrage zu Objekten u. Übergabeparameter Java Basics - Anfänger-Themen 8
arjoopy Kapselung Übergabe von Objekten aus ArrayList Java Basics - Anfänger-Themen 4
schoenosrockos Unterschied zwischen Objekten und vererbungen Java Basics - Anfänger-Themen 1
M Speichern von Objekten - Verfügbarkeit bei erneutem Aufruf Java Basics - Anfänger-Themen 3
R Methoden Methode ruft Methode auf, ruft Methode auf (mit Objekten) Java Basics - Anfänger-Themen 4
S Serialisierung: Laden von Objekten - Risiken? Java Basics - Anfänger-Themen 4
E Instanzieren von Objekten verkürzen Java Basics - Anfänger-Themen 1
F Interaktion von Objekten verschiedener Klassen... Java Basics - Anfänger-Themen 13
D Effiziente Verwaltung der Objekten und Unterobjekten Java Basics - Anfänger-Themen 18
N Dauer zwischen zwei LocalDateTime Objekten berechnen? Java Basics - Anfänger-Themen 4
L Subklasse von ArrayList nur mit bestimmten Objekten füllen Java Basics - Anfänger-Themen 1
E Erste Schritte Gute Erklärung zu Objekten / Klassen / Methoden / Sichtbarkeiten auf Deutsch Java Basics - Anfänger-Themen 3
S Problem mit augabe von Objekten Java Basics - Anfänger-Themen 3
T Junit Mockito: Instanz von inneren erzeugten Objekten Java Basics - Anfänger-Themen 4
P Zugriff auf Felder in ArrayList Objekten Java Basics - Anfänger-Themen 2
W Was passiert mit Objekten die nicht in Objektvariablen initialisiert werden ? Java Basics - Anfänger-Themen 3
D Zugriff auf von einer anderen Klasse erstellten Objekten Java Basics - Anfänger-Themen 5
S Liste mit Objekten und Listen Java Basics - Anfänger-Themen 9
Y Gleiche Arrays aus einem Array mit Objekten Java Basics - Anfänger-Themen 5
K Min eines Arrays mit Objekten Java Basics - Anfänger-Themen 6
M Array mit Objekten lässt sich nicht auslesen Java Basics - Anfänger-Themen 10
T Statische Arrays von Objekten Java Basics - Anfänger-Themen 2
J Methoden Einfügen von Objekten nach Alphabet in ArrayList funktioniert nicht Java Basics - Anfänger-Themen 2
B Erste Schritte Anzeige von Graphics Objekten einzeln aktualisieren Java Basics - Anfänger-Themen 1
TheSorm Koordinaten von gedrehten Objekten Java Basics - Anfänger-Themen 4
D Bestimmte Werte von Objekten aus einer ArrayList in eine andere ArrayList kopieren Java Basics - Anfänger-Themen 14
B Aliasing bei null-Objekten Java Basics - Anfänger-Themen 3
O Java Erzeugung von neuen Objekten Java Basics - Anfänger-Themen 1
J Verständnisfragen zu dem Thema Objekten Java Basics - Anfänger-Themen 7
J Array von Objekten, wie schauts im Heap / Stack aus ? Java Basics - Anfänger-Themen 7
O Größe von Objekten Java Basics - Anfänger-Themen 5
Y Variable Menge von Objekten erzeugen und mit ihren Attributen rechnen Java Basics - Anfänger-Themen 7
kaoZ Best Practice Verständnisfrage Listener bei lokalen Objekten Java Basics - Anfänger-Themen 8
F Umgang mit referenzierten Objekten bei ArrayList Java Basics - Anfänger-Themen 1
M Löschen von Objekten während Iteration über Liste Java Basics - Anfänger-Themen 9
E Array von Objekten einer selbst definierten Klasse mit eindeutigem Namen Java Basics - Anfänger-Themen 2
C For schleife mit Array und Objekten Java Basics - Anfänger-Themen 17
kaoZ Input/Output Android : Deserialisieren von mehreren Objekten in einer Datei Java Basics - Anfänger-Themen 0
U Übergabe von Objekten Java Basics - Anfänger-Themen 0
C Werte aus zwei Objekten miteinander vergleichen Java Basics - Anfänger-Themen 3
Joew0815 Interface JSON Objekte aus Java Objekten erzeugen Java Basics - Anfänger-Themen 9
D Sortieren von int Werten von Objekten in einer LinkedList, kann nicht auf int Werte zugreifen Java Basics - Anfänger-Themen 3
E Erste Schritte Sortieren von Objekten in doppelt-verlinkter Liste Java Basics - Anfänger-Themen 9
R addition von 2 Array Objekten Java Basics - Anfänger-Themen 5
V Grundlegendes Zu Objekten/Klassen Java Basics - Anfänger-Themen 10
S Problem bei Kollision zwischen Array-objekten! Java Basics - Anfänger-Themen 2
C Probleme mit neuen Objekten Java Basics - Anfänger-Themen 3
S Erste Schritte Bluej Automatisches Einfügen von Objekten Java Basics - Anfänger-Themen 4
D ID von Objekten in Arraylist Java Basics - Anfänger-Themen 3
B Datentypen Inhalt von Objekten miteinander vergleichen Java Basics - Anfänger-Themen 2
R Erste Schritte Objekte mit anderen Objekten als Inhalt Java Basics - Anfänger-Themen 4
V Frage zum Löschen von Objekten Java Basics - Anfänger-Themen 2
C ArrayList mit Objekten Java Basics - Anfänger-Themen 4
P Mindestangaben beim anlegen von Objekten Java Basics - Anfänger-Themen 4

Ähnliche Java Themen

Neue Themen


Oben