In LinkedList einen Wert ersetzen oder neu einfügen

Fohnbit

Top Contributor
Hallo,

ich speichere Zustände in einer LinkedList:
Java:
private LimitedQueue<RecEvent> recordedEvents = new LimitedQueue<RecEvent>(5000, 86400);
RecEvent e = new RecEvent(id, key, timeStamp, value, desc);
recordedEvents.add(e);

Es liegt der Klasse "LimitedQueue" eine LinkedList zugrunde.

Nun muss ich bei der Zeile:
Java:
RecEvent e = new RecEvent(id, key, timeStamp, value, desc);
entscheiden, ob der Wert mittels "add" hinzugefügt wird oder ob ein älterer Eintrag überschrieben werden soll.
Wenn id und key über einstimmen, soll überschrieben werden, wenn der timeStamp weniger als 5sek auseinander liegt und sonst normal hinzufügen.

Nun könnte ich einen Loop über die ganze recordedEvents machen:
Java:
        ListIterator<RecEvent> listIterator = recordedEvents.listIterator();

                        while (listIterator.hasNext()) {
                            RecEvent ee = listIterator.previous();
                            if (ee.getObjId().equals(e.getObjId()) && ee.getKey().equals(e.getKey())) {
                              
    if ((ee.getTs() + 5000) < e.getTs()) {
                                    listIterator.remove();
                                    recordedEvents.add(e);
                                    break;
                                } else {
                                    recordedEvents.add(e);
                                    break;
                                }
                            }
                        }

Aber ist das ein dankbarer Weg und klappt das mit dem löschen und neu einfügen so wie im Beispiel oben?

Danke!
 
Zuletzt bearbeitet:

Fohnbit

Top Contributor
Mich würde es interessieren, ob es einen besseren Ansatz gibt.
Und ob listIterator.remove() und recordedEvents.add(e) so richtig angewendet ist.

Danke!
 

Fohnbit

Top Contributor
Hallo,

habs nun mal versucht und klappt noch nicht ganz:
Java:
        ListIterator<RecEvent> listIterator = recordedEvents.getQueue().listIterator(recordedEvents.size());

                            while (listIterator.hasPrevious()) {
                                RecEvent ee = listIterator.previous();
                                if (ee.getObjId().equals(e.getObjId()) && ee.getKey().equals(e.getKey())) {
                                    if ((ee.getTs() + 5000) < e.getTs()) {
                                        listIterator.remove();
                                        recordedEvents.add(e);
                                        break;
                                    } else {
                                        recordedEvents.add(e);
                                        break;
                                    }
                                }
                            }

Scheinbar wird das ".remove()" nicht ausgeführt, da die Größe der List immer erhöht wird.
Innerhalb von 5 Sekunden sollte der alte Eintrag gelöscht und der neue eingefügt werden.

Ich bekomme die Linklist von einer Klasse zurück:
public LinkedList<RecEvent> getQueue() {
return linkedList;
}

Aber sollte ja nur ein Zeiger sein und direkt auf die List zugreifen, oder?
Denn ich lösche mit "listIterator" and füge aber mit "recordedEvents" hinzu.

Aber die Einträge werden anscheinend nicht aus der Liste gelöscht.
 

Fohnbit

Top Contributor
sorry :)

so ist es richtig ... falscher Größenvergleicher:
Java:
ListIterator<RecEvent> listIterator = recordedEvents.getQueue()
                                    .listIterator(recordedEvents.size());

                            while (listIterator.hasPrevious()) {
                                RecEvent ee = listIterator.previous();
                                if (ee.getObjId().equals(e.getObjId()) && ee.getKey().equals(e.getKey())) {
                                    System.out.println("Timediff: " + (ee.getTs() + 5000) + " from "+  e.getTs());
                                    if ((ee.getTs() + 5000) > e.getTs()) {
                                        listIterator.remove();
                                        recordedEvents.add(e);
                                        break;
                                    } else {
                                        recordedEvents.add(e);
                                        break;
                                    }
                                }
                            }
 

Kababär

Top Contributor
Hmmm... ich glaube du musst eher hingehen und da mit Threads arbeiten? Kann aber sein, dass ich mich irre. Ich persönlich würde mit Threads mit Callbacks arbeiten, so dass sich der Thread meldet, wenn 5 Sekunden vergangen sind und dann geprüft wird, ob der Eintrag gelöscht werden soll.

Bei dem Ansatz hier weiß ich gerade nicht weiter, vllt kann jemand anderes helfen.
 
Zuletzt bearbeitet:

Joose

Top Contributor
Hmmm... ich glaube du musst eher hingehen und da mit Threads arbeiten? Kann aber sein, dass ich mich irre. Ich persönlich würde mit Threads mit Callbacks arbeiten, so dass sich der Thread meldet, wenn 5 Sekunden vergangen sind und dann geprüft wird, ob der Eintrag gelöscht werden soll.
Threads werden hier nicht gebraucht ;)
Bei den erwähnten 5 Sekunden handelt es sich nur um die Differenz von den TimeStamps zweier RevEvent Objekte ;)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
A LinkedList implementieren Java Basics - Anfänger-Themen 32
M Wie kann ich den Index i von einer LinkedList überprüfen? Java Basics - Anfänger-Themen 36
Düsseldorf2002 Datentypen Verschachtelte LinkedList Java Basics - Anfänger-Themen 5
Düsseldorf2002 Datentypen Zwei dimensionale LinkedList Java Basics - Anfänger-Themen 8
B Warteschlange erstellen mit LinkedList ? Java Basics - Anfänger-Themen 6
U Objekte in LinkedList löschen und editieren Java Basics - Anfänger-Themen 14
G Java LinkedList remove Methode Java Basics - Anfänger-Themen 5
G Java LinkedList Java Basics - Anfänger-Themen 6
U Objekte in einer LinkedList sortieren Java Basics - Anfänger-Themen 5
S Eigene LinkedList Klasse Java Basics - Anfänger-Themen 4
S Mit einer LinkedList vorwärts und rückwärts iterieren Java Basics - Anfänger-Themen 6
S Endlosschleife beim Ausgeben einer LinkedList Java Basics - Anfänger-Themen 2
G Java LinkedList Java Basics - Anfänger-Themen 3
B LinkedList add-Methode Java Basics - Anfänger-Themen 10
F Windows in LinkedList registrieren Java Basics - Anfänger-Themen 3
A Hilfe, LinkedList Java Basics - Anfänger-Themen 2
H Knoten-Reihenfolge einer LinkedList invertieren Java Basics - Anfänger-Themen 11
H linkedlist generische klassen Java Basics - Anfänger-Themen 169
O Hashmap, ArrayList, LinkedList Java Basics - Anfänger-Themen 7
P Quellcode LinkedList Java Basics - Anfänger-Themen 2
F Collection Aufgabe mit LinkedList Java Basics - Anfänger-Themen 3
N Hilfe bei verknüpfter Liste - Linkedlist Java Basics - Anfänger-Themen 11
P Datentypen LinkedList: Kopie behält Referenz? Java Basics - Anfänger-Themen 3
C ArrayList vs LinkedList vs ? Java Basics - Anfänger-Themen 15
C LinkedList vs. ArrayList Java Basics - Anfänger-Themen 15
O LinkedList zu ArrayList Java Basics - Anfänger-Themen 4
M LinkedList elemente löschen Java Basics - Anfänger-Themen 2
L Problem mit LinkedList Java Basics - Anfänger-Themen 3
P Hashmap anstatt LinkedList? Java Basics - Anfänger-Themen 6
TechGirl LinkedList - kurze allgemeine Frage Java Basics - Anfänger-Themen 17
B generische LinkedList nach Häufigkeit der Elemente füllen Java Basics - Anfänger-Themen 6
L LinkedList Comparable < > MEHRFACH implementieren? Java Basics - Anfänger-Themen 3
S LinkedList mit Input vergleichen. Java Basics - Anfänger-Themen 5
C Bei der LinkedList auf Palindrom überprüfen Java Basics - Anfänger-Themen 4
F Element aus LinkedList löschen Java Basics - Anfänger-Themen 3
A LinkedList: Probleme beim Auslesen Java Basics - Anfänger-Themen 2
T Collections LinkedList<LinkedList<T>> - Implementierung Java Basics - Anfänger-Themen 10
S Jfreechart mit LinkedList befüllen Java Basics - Anfänger-Themen 1
S JTable LinkedList <Objekt> befüllen Java Basics - Anfänger-Themen 1
K LinkedList aus Arrays ( Lösungsraum Mastermind ) Java Basics - Anfänger-Themen 5
Z Compiler-Fehler LinkedList Fragen Java Basics - Anfänger-Themen 4
K Methoden Probleme mit LinkedList.remove(object) Java Basics - Anfänger-Themen 1
Farbenfroh int in LinkedList einsortieren Java Basics - Anfänger-Themen 4
W Klassen LinkedList funktioniert nicht Java Basics - Anfänger-Themen 6
X LinkedList - Index eines Objekts Java Basics - Anfänger-Themen 2
S Strings in eine LinkedList schreiben und auslesen? Java Basics - Anfänger-Themen 4
D Sortieren von int Werten von Objekten in einer LinkedList, kann nicht auf int Werte zugreifen Java Basics - Anfänger-Themen 3
F Eigene LinkedList - toString Java Basics - Anfänger-Themen 10
T Datentypen gleichmäßiges mischen von 2 LinkedList Java Basics - Anfänger-Themen 3
S Dateien/LinkedList/StringBuffer - SOrtierung klappt nicht so ganz Java Basics - Anfänger-Themen 2
J Datentypen Array von einer LinkedList Java Basics - Anfänger-Themen 5
R LinkedList Java Basics - Anfänger-Themen 8
J Per I/O Streams in LinkedList oder ArrayList schreiben/lesen Java Basics - Anfänger-Themen 6
B LinkedList remove Java Basics - Anfänger-Themen 5
J statische Methoden auf eine LinkedList initialisieren? Java Basics - Anfänger-Themen 5
G Hausaufgabe mit LinkedList und LinkedListStack verstehen Java Basics - Anfänger-Themen 6
N LinkedList-checkForComodification Java Basics - Anfänger-Themen 11
N LinkedList Java Basics - Anfänger-Themen 17
P LinkedList sortieren Java Basics - Anfänger-Themen 20
P LinkedList - Stack ... grundlegende Frage Java Basics - Anfänger-Themen 5
Z Erste Schritte LinkedList Werte abfragen und vergleichen Java Basics - Anfänger-Themen 3
B SUCHE: Threadsafe LinkedList Java Basics - Anfänger-Themen 10
Binary.Coder Wie linkedlist für Djikstra nutzen? Java Basics - Anfänger-Themen 6
M Arrays in LinkedList Java Basics - Anfänger-Themen 4
R Collections Probleme mit contains()-Methode [LinkedList] Java Basics - Anfänger-Themen 5
G Collections.binarySearch(LinkedList): cannot find method Java Basics - Anfänger-Themen 6
M LinkedList aktuelle position Java Basics - Anfänger-Themen 3
G Frage zu LinkedList Java Basics - Anfänger-Themen 15
H Dynamische Bindung mit Interfaces und LinkedList Java Basics - Anfänger-Themen 7
I LinkedLIst / ArrayList Konstruktor Java Basics - Anfänger-Themen 4
B Collections RandomAccessfile & Linkedlist Java Basics - Anfänger-Themen 4
S Speichermangel ArrayList/LinkedList Java Basics - Anfänger-Themen 3
V LinkedList size() Java Basics - Anfänger-Themen 2
darekkay Datentypen HashSet bzw. LinkedList mit Werten initialisieren Java Basics - Anfänger-Themen 3
D Probleme mit LinkedList Java Basics - Anfänger-Themen 6
L LinkedList vorgänger Knoten zurück geben Java Basics - Anfänger-Themen 4
S LinkedList indexOf() - geht des irgendwie schneller? Java Basics - Anfänger-Themen 23
S LinkedList<String[]> filtern und sortieren Java Basics - Anfänger-Themen 9
W LinkedList Java Basics - Anfänger-Themen 12
S Frage zum speichern der Daten in einer LinkedList Java Basics - Anfänger-Themen 2
D Fenster in LinkedList verwalten Java Basics - Anfänger-Themen 2
C HashMap mit LinkedList Java Basics - Anfänger-Themen 5
S Datentypen LinkedList Konstruktor, add Alternative Java Basics - Anfänger-Themen 2
truesoul LinkedList Problem Java Basics - Anfänger-Themen 6
M Java Generics LinkedList Java Basics - Anfänger-Themen 5
H LinkedList Element an Stelle x ausgeben? Java Basics - Anfänger-Themen 5
D LinkedList aufrufe Java Basics - Anfänger-Themen 3
S Problem mit ObjectInputStream beim Einlesen von LinkedList Java Basics - Anfänger-Themen 3
S Serialized LinkedList aus Datei Laden Java Basics - Anfänger-Themen 15
S LinkedList Java Basics - Anfänger-Themen 2
M LinkedList in anderer Klasse nutzen Java Basics - Anfänger-Themen 4
L LinkedList sortieren Java Basics - Anfänger-Themen 5
L heap space, LinkedList umspeichern Java Basics - Anfänger-Themen 15
H LinkedList mit Strings Exception Java Basics - Anfänger-Themen 3
S IndexOutofBoundsException bei linkedlist Java Basics - Anfänger-Themen 5
B Fehlersuche bei LinkedList Java Basics - Anfänger-Themen 3
B LinkedList - Berechnung des Produkts Java Basics - Anfänger-Themen 6
S Sortierte LinkedList nach Variablen durchsuchen und nicht nach INDEX Java Basics - Anfänger-Themen 6
B Unterschied ArrayList und LinkedList Java Basics - Anfänger-Themen 5
S Implementierung gegen Interfaces / List, ArrayList, LinkedList Java Basics - Anfänger-Themen 11

Ähnliche Java Themen

Neue Themen


Oben