Objekte in mehreren Listen

propra

Aktives Mitglied
Hallo zusammen,

ich habe Objekte vom Typ Knoten und Kante. Innerhalb der Klasse Knoten habe ich zwei ArrayList's (incommingEdges und outgoingEdges), welche die Information darüber, welche Kante in den Knoten ein- bzw. ausläuft, speichern. Erzeuge ich nun eine Kante, wird sie den entsprechenden Knoten als ein- bzw. ausgehend hinzugefügt.
Bisher bin ich immer davon ausgegangen, dass wenn ich nun eine Kante lösche, sie sich auch automatisch aus den beiden Listen löscht, da in den Listen nur Referenzen auf das Kanten-Objekt gespeichert werden.
Dies scheint aber nicht der Fall zu sein. Kann mir jemand sagen, was an meiner Überlegung falsch ist?
Wird ein Objekt erst gelöscht, wenn es keine Referenzen zu ihm gibt?
Gibt es eine Möglichkeit alle Referenzen auf ein Objekt zu löschen?
Das ganze soll dazu führen, dass sobald ein Knoten gelöscht wird, auch alle ein- bzw. ausgehenden Kanten gelöscht werden.

Vielen Dank vorab.
 
B

bygones

Gast
was machst du denn bei "kante loeschen" ? einfach auf null setzen reicht nicht aus

du musst dafuer sorgen, dass wenn ein Knoten geloescht wird, alle Kanten dementsprechend aktualisiert werden. Von Zauberhand geht nix
 

akimoon

Aktives Mitglied
Ich weiß keine "schöne" Lösung zu dem Problem (außer dass man in einer externen Liste oder im Objekt selbst speichert, zu welchen Listen es gehört. Oder dass man die Listen alle durchgeht und überprüft.. aber vllt weiß hier jemand eine bessere Lösung).

Dafür habe ich eine kleine Frage: Wie hast du das Objekt denn gelöscht?
Wenn du wie gesagt einfach
Code:
k = null
setzt heißt das nur, dass k auf null referenziert.
Das Objekt bleibt trotzdem in Speicher, und werden weiterhin von den anderen Listen refenziert.
 

propra

Aktives Mitglied
Jetzt wo ihr es sagt, fällt mir gerade auf, dass eine Kante gar nicht gelöscht wird, sondern nur eine Referenz darauf.
Die anderen bleiben ja bestehen, weshalb auch das Objekt noch "lebt".
Dann bleibt mir wohl nur der Weg über alle Listen zu referenzieren und dann die Referenzen auf die Kanten zu löschen.

Ich stelle mir jetzt gerade die Frage, ob mein Ansatz überhaupt sinnvoll ist.
Wie gesagt, geht es mir darum beim Löschen eines Knoten auch gleichzeitig alle ein- und ausgehenden Kanten zu löschen. Eine Kante hat ohnehin die Information darüber, wer sein Start- und Endknoten ist.
Wenn ich nun einfach alle Kanten darauf überprüfe, ob der zu löschende Knoten einem der Start- bzw. Endknoten entspricht, sollte sich das Löschen doch einfacher gestalten, oder?

Freue mich auch gerne über weitere Vorschläge.
 
B

bygones

Gast
wenn ich dein setup richtig verstanden habe ist etwas zyklisch.

Eine Kante kennt seinen Ursprungsknoten und Zielknoten.
Jeder Knoten kennt seine incoming und outgoing Kanten.

D.h. beim loeschen eines Knoten musst du zum einen ueber alle Kanten laufen und die Kanten loeschen bei denen der Knoten war, dann aber auch nochmal ueber alle Knoten laufen um die geloeschten Kanten zu entfernen.

Eine Moeglichkeit waere die Kanten so zu behalten wie sie sind, aber die Knoten nicht ueber incoming oder outgoing kanten wissen zu lassen. Diese information kann ja immer aus den Kanten gezogen werden.
 

Marco13

Top Contributor
Davon ausgehend, dass das ein normaler Graph ist: Dann gibt es auch eine Methode wie "removeEdge(Edge)", und wenn man einen Knoten löscht, kann man sowas machen wie
Java:
List<Edge> edgesToRemove = new ArrayList<Edge>();
edgesToRemove.addAll(node.incomingEdges());
edgesToRemove.addAll(node.outgoingEdges());
for (Edge e : edgesToRemove) removeEdge(e);
Die Listen in den Knoten sollten bei geeigneter Implementierung der removeEdge-Methode automatisch aktualisiert werden.
 

propra

Aktives Mitglied
Ja, es ist in der Tat etwas zyklisch.
Muss es aber leider auch beibehalten, da ich die Informationen, welche Kannte ein- bzw. ausgehend ist, schon benutze und nicht abschätzen kann, wie aufwändig eine Änderung wäre. Möchte mir ungern eine zusätzliche Baustelle schaffen.

Probiere es von daher erst einmal mit dem durchlaufen aller Listen.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
I Zapier -> wie werden Objekte gespeichert? Java Basics - Anfänger-Themen 10
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
K Hab ich dass so richtig erklärt (Objekte und Referenzen)? Java Basics - Anfänger-Themen 5
J Objekte in JSON speichern?? Java Basics - Anfänger-Themen 1
I Objekte in ShareProject speichern um später zu nutzen Java Basics - Anfänger-Themen 4
J Objekte Java Basics - Anfänger-Themen 22
T Objekte mit arrays erstellen Java Basics - Anfänger-Themen 6
Hzrfa Objekte, Referenz Java Basics - Anfänger-Themen 5
T 3D Objekte verarbeiten Java Basics - Anfänger-Themen 2
N Welche Objekte kann man zu einem Set hinzufügen Java Basics - Anfänger-Themen 4
I XML einlesen und Objekte bekommen Java Basics - Anfänger-Themen 2
W Objekte einer ArrayList in txt-datei schreiben mit Paths? Java Basics - Anfänger-Themen 2
Encera Zugriff auf Map-Objekte Java Basics - Anfänger-Themen 3
E Objekte löschen Java Basics - Anfänger-Themen 9
P Array-Objekte-Aufruf Java Basics - Anfänger-Themen 22
Encera Auf Objekte aus anderer Klassen zugreifen Java Basics - Anfänger-Themen 20
P Zähler Variable für mehrere Objekte Java Basics - Anfänger-Themen 6
B Objekte verschwinden beim Übersetzen Java Basics - Anfänger-Themen 5
D Zwei verschiedene Intellij Projekte, wie benutze ich wechselseitig objekte Java Basics - Anfänger-Themen 8
E Rekursiv Objekte erzeugen - geht das? Java Basics - Anfänger-Themen 2
T Collections Sind Subklassen-Objekte in Listen mit Generics erlaubt? Java Basics - Anfänger-Themen 16
F Aus eingelesener Datei korrekt Objekte erzeugen Java Basics - Anfänger-Themen 5
G Übergeordnete Objekte abrufen Java Basics - Anfänger-Themen 9
B Bin komplett am verzweifeln :( Verkettete Liste die Objekte hat Attribut auslesen Java Basics - Anfänger-Themen 14
A Objekte mit Parametern in eine Liste packen Java Basics - Anfänger-Themen 19
B Objekte, bspw. konkret Arraylists,manuell aus Speicher löschen? Java Basics - Anfänger-Themen 70
S Objekte von zwei klassen in zwei verschiedene Textdateien schreiben Java Basics - Anfänger-Themen 5
D Wie Objekte im JFrame frei bewegen lassen? Java Basics - Anfänger-Themen 3
Spandeli8 Erzeugte Objekte gegenüber Bildern hervorheben in Java Processing Java Basics - Anfänger-Themen 1
J Zwei Objekte vergleichen Java Basics - Anfänger-Themen 8
L Werte von Objekte addieren Java Basics - Anfänger-Themen 14
U Objekte in LinkedList löschen und editieren Java Basics - Anfänger-Themen 14
W Objekte über Scanner Input; ToString Probleme... Java Basics - Anfänger-Themen 4
J Problem mit einer Methode, die beliebig viele Objekte in Array speichern soll Java Basics - Anfänger-Themen 6
G Methoden Informationen aus zwei Objekte bekommen? Java Basics - Anfänger-Themen 6
P Globale Objekte Java Basics - Anfänger-Themen 2
C Nachträglich neue grafische Objekte hinzufügen Java Basics - Anfänger-Themen 7
D Interaktion zweier Objekte Java Basics - Anfänger-Themen 5
M Objekte in Array speichern und ausgeben Java Basics - Anfänger-Themen 17
S Objekte indiziert erstellen Java Basics - Anfänger-Themen 27
M Warum dürfen Objekte einer Klasse auf statische Variablen dieser Klasse referenzieren? Java Basics - Anfänger-Themen 10
M Objekte mittels equals vergleichen Java Basics - Anfänger-Themen 14
C Fernseher-Aufgabe (Methoden, Klassen und Objekte) Java Basics - Anfänger-Themen 63
N Typebound Objekte einer Arraylist hinzufügen Java Basics - Anfänger-Themen 7
A (Objekte Java Basics - Anfänger-Themen 6
Y Klassen Klassen und Objekte Java Basics - Anfänger-Themen 3
Y Klassen Klassen und Objekte mit set und get Java Basics - Anfänger-Themen 0
U Objekte in einer LinkedList sortieren Java Basics - Anfänger-Themen 5
N Methode um Objekte einer Liste hinzuzufügen Java Basics - Anfänger-Themen 1
G Java Objekte auf Duplikate testen Java Basics - Anfänger-Themen 4
B Neue Liste erstellen, wenn Objekte bestimmte Referenz hat / Gruppierung von Einträgen Java Basics - Anfänger-Themen 12
M Implementieren einer Datenstruktur, welche nur 5 Objekte speichert Java Basics - Anfänger-Themen 3
M Objekte miteinander vergleichen Java Basics - Anfänger-Themen 18
C Verschiedene Objekte in einer Liste speichern Java Basics - Anfänger-Themen 6
J Java GUI- Objekte Position per Quelltext bestimmen Java Basics - Anfänger-Themen 4
G Objekte in Methoden? Java Basics - Anfänger-Themen 13
H Auf Objekte bzw Variabeln aus einer anderen Methode zugreifen Java Basics - Anfänger-Themen 7
S Frage Klasse und Objekte Java Basics - Anfänger-Themen 2
K Boolean in einer Methode um 2 Objekte zu vergleichen Java Basics - Anfänger-Themen 12
I Objekte Hilfe Java Basics - Anfänger-Themen 8
G Klassen und Objekte Java Basics - Anfänger-Themen 2
W Verschachtelte Objekte wieder auspacken Java Basics - Anfänger-Themen 3
R Attribute mehrerer Objekte ausgeben Java Basics - Anfänger-Themen 3
C Objekte und Konstruktoren Java Basics - Anfänger-Themen 2
F Erstellen zweier Objekte mit dem selben Inhalt Java Basics - Anfänger-Themen 1
O ObjectOutputStream Anzahl Objekte festhalten Java Basics - Anfänger-Themen 17
R Objekte aus Array als String + kommasepariert speichern Java Basics - Anfänger-Themen 12
X Objekte einer ArrayList richtig ausgeben? Java Basics - Anfänger-Themen 8
J Best Practice Dateiinhalte validieren und auf Objekte mappen Java Basics - Anfänger-Themen 3
B Automatisch Objekte erzeugen mit verschiedenen Namen Java Basics - Anfänger-Themen 4
der_Schokomuffin Hilfe gesucht beim Thema Objekte übergeben! Java Basics - Anfänger-Themen 2
S Konstruktor, Objekte Java Basics - Anfänger-Themen 4
PaperHat Objekte in Array vergleichen Java Basics - Anfänger-Themen 9
B HTML Code / Seite auslesen und JAVA Objekte erstellen Java Basics - Anfänger-Themen 12
PaperHat Programmieraufgabe - Objekte in Objekten Java Basics - Anfänger-Themen 2
E Methode mit Parametern um Objekte zu übergeben Java Basics - Anfänger-Themen 4
V Collections Objekte einer ArrayList in der main() ausgeben Java Basics - Anfänger-Themen 9
T Klassen Klassenübergreifende Objekte erstellen lassen Java Basics - Anfänger-Themen 5
A Objekte verknüpfen Java Basics - Anfänger-Themen 2
M Objekte mit einer Schleife mehrmals erzeugen Java Basics - Anfänger-Themen 17
B Klassen Alle Unter-Objekte durchlaufen in der Hauptklasse Java Basics - Anfänger-Themen 10
B Objekte zählen/ Vererbung/ Kopplung/ Interface/ Abstract Class Java Basics - Anfänger-Themen 5
S Zählen der Zeiger auf Objekte Java Basics - Anfänger-Themen 35
J Methoden Equals Methode für Integer und Objekte überschreiben? Java Basics - Anfänger-Themen 9
B Erste Schritte Objekte von JFrame der Fenstergröße anpassen Java Basics - Anfänger-Themen 3
M Klassen und Objekte Java Basics - Anfänger-Themen 2
J Objekte und Abstrakte Klassen Java Basics - Anfänger-Themen 2
J Array Objekte einer Klasse zuordnen Java Basics - Anfänger-Themen 15
H Interface Objekte speichern und laden (serialisieren/deserialisieren) Java Basics - Anfänger-Themen 1
Orkanson Objekte in ein Array einfügen Java Basics - Anfänger-Themen 5
X Objekte in ArrayList einfügen Java Basics - Anfänger-Themen 10
L Vorherige Objekte zählen und ausgeben Java Basics - Anfänger-Themen 11
Orkanson Objekte und Klassen Java Basics - Anfänger-Themen 8
R Objekte zur Laufzeit in Schleife erzeugen und in ArrayList ablegen Java Basics - Anfänger-Themen 4
D Objekte-Fragen Java Basics - Anfänger-Themen 1
T Objekte in der Methode Java Basics - Anfänger-Themen 8
F Alle Objekte einer Klasse nach Eigenschaft durchsuchen Java Basics - Anfänger-Themen 8
R Interface Eigene Objekte in Listen sortieren mit Interface Comparable Java Basics - Anfänger-Themen 5
E Eine Instanzvariable und zwei Objekte Java Basics - Anfänger-Themen 14
N Objekte in ArrayList finden Java Basics - Anfänger-Themen 10

Ähnliche Java Themen

Neue Themen


Oben