Tiefe Kopie einer Baumstruktur als statische Methode

Status
Nicht offen für weitere Antworten.

SamHotte

Top Contributor
Moin,
ich habe eine sehr umfangreiche Baumstruktur und brauche relativ oft kleine Ausschnitte daraus. Der Baum selbst ist als Singleton realisiert, da die Änderungen in eine Datenbank geschrieben werden bzw. von dort gelesen wird.
Für die Ausschnitte habe ich momentan eine separate Klasse, die aus dem Singleton-Baum eine spezielle Instanz erzeugt. Das finde ich nicht wirklich praktisch, da ich im Programm recht oft mal das eine und mal das andere benötige.
Um den Stil zu verbessern (und einige Konstruktoren einzusparen), wollte ich meine konstruktorenbasierte Kopiererei durch eine schön benamste statische Methode abwickeln lassen. Da der Baum allerdings rekursiv zusammengesetzt wird, brauche ich ständig Methodenaufrufe - und da wird angemeckert, dass ich von einem statischen Kontext keine non-static Methode aufrufen kann. Zu einem drastischen Ende des "verstatischen" meiner bisherigen Ergüsse kommt es nun, wenn ich eine Instanzmethode der Superklasse aufrufen muss :bahnhof:
Gibt's da irgendeinen Trick? Die Methoden der Superklasse fügen Elemente in eine Map ein, sodass ich dort ja wohl um eine Instantiierung nicht herumkomme, oder?
[schild=1]Ideen gesucht[/schild]
 

AlArenal

Top Contributor
Warum realisierst du deine "Ausschnitte" nicht als ein TreeModel, dass auf das Singleton-TreeModel zugreift und einfach nur nen anderen Root-Knoten hat?
 

SamHotte

Top Contributor
Mach ich im Prinzip ja. Die Ausschnitte sind Bäume, die aus den vom Originalbaum ausgewählten Blättern bestehen (plus die jeweiligen Pfade zur Wurzel). Da ich nur die Blätter in der Datenbank speichere, muss ich die Ausschnitte immer wieder unterschiedlich zusammensetzen, also jeweils einen "neuen" Baum kreieren, und dazu brauche ich so grundsätzliche Funktionalität wie "Knoten unter Vater einfügen" ...
 

AlArenal

Top Contributor
Ja, aber die brauchste doch nur einmal implementieren und auch nicht statisch. Du kannst insert/move/...-Operationen im Singleton-TreeModel implementieren und in den Ausschnitt-Model reichst du einfach nur an die Methoden des Singleton weiter. Über die entsprechenden von dir implementierten Listener erfahren die abgeleiteten Model dann auch von Änderungen und aktualisieren sich.
 

SamHotte

Top Contributor
Hm, kapier ich nicht ganz - im Singleton-Modell stoße ich bei insert/move/delete die jeweiligen Datenbankoperationen an, was ich im Ausschnittsfall nicht möchte. Also kann ich ja nicht weiterleiten.
Das mit dem Verweisen auf das originale Modell kann ich mir auch nicht so recht vorstellen, da handle ich mir doch die Original-Kinder der Knoten ein (und genau das will ich beim Ausschnitt nicht).
 

Bleiglanz

Gesperrter Benutzer
vergiss einfach das Singleton und den ganzen static Zeugs?

Warum nicht gute alte Instanzen, bei richtiger Programmierung passiert da auch nix schlimmes wenn du die Erzeugung neuer Bäume genau kontrollierst!

Und: wie hast du denn deinen Baum implementiert?

vergiss mal das TreeModel und denk drüber nach
Code:
class Node {
    Node parent; 
        // eh klar, nur die Wurzel hat hier null
    "Liste von Nodes" children; 
        // eigentlich redundant aber praktisch
    .. 
}
d.h. ein Baum ist einfach ein Knoten mit Kindern, und wenn du einen "Ausschnitt" willst, dann nimmst du einfach den entsprechenden Knoten, man braucht dazu überhaupt nix zu programmieren?
 

SamHotte

Top Contributor
Singleton oder nicht ist wurscht, das stimmt schon. Ich hab's halt so gebaut, wäre anders auch denkbar. Ist aber nicht Kern des Problems.

Ich hab für meinen Baum TreeModel implementiert und sammle die Knoten in einer TreeMap. Ich brauche im Knoten noch ein bisschen mehr Info, da es in meinem Baum auf die Reihenfolge der Kinder ankommt. Aber auch das klappt.

Jetzt zum Problem: ich habe eine Liste anderer Objekte, die mit einzelnen Knoten verknüpft sind; dabei kann ich sowohl Blätter als auch "echte" Knoten wählen. Wenn ich nun in der Liste ein Element auswähle, möchte ich in meinem Panel daneben einen Baum sehen, der nur aus den ausgewählten Knoten besteht. Die im Originalbaum vorhandenen Kinder sollen quasi "weggefiltert" werden.
Das realisiere ich eben über neue Bäume, die auf Basis des Originals erstellt werden (nur dort bekomme ich den Pfad zur Wurzel).
 

SamHotte

Top Contributor
Besten Dank, den Ansatz über Filter werde ich mal ausprobieren! Schade, dass man sowas in keinem herkömmlichen Buch findet ... :)
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
C Best Practice Tiefe Kopie eines Arrays unbekannter Dimension und unbekannten Typs Allgemeine Java-Themen 4
C Methode für tiefe Kopie eines unbekannt (dimensionierten & typisierten) Feldes realisierbar? Allgemeine Java-Themen 7
E tiefe Kopie nicht serialisierbarer Objekte Allgemeine Java-Themen 3
U Tiefe Objekte schreiben Allgemeine Java-Themen 1
D Datenstruktur für Hierarchie/Baum mit Tiefe 3 Allgemeine Java-Themen 8
B tiefe gleichheit / flache gleichheit Allgemeine Java-Themen 5
W Tiefe eines Knotens Allgemeine Java-Themen 3
M Verschachtelte Schleifen (unbekannte Tiefe) Allgemeine Java-Themen 3
Linad Tiefe der Rekursion als Abbruchbedingung Allgemeine Java-Themen 6
M Neue Instanz/Kopie einer unbekannten Klasse Allgemeine Java-Themen 7
reibi Kopie einer Liste Allgemeine Java-Themen 4
J Collections in Instanzattributen als Kopie übergeben Allgemeine Java-Themen 4
N for (String s : StringArray) : Kopie oder Verweis? Allgemeine Java-Themen 9
M "Kopie" von JLabels werden nicht gezeichnet Allgemeine Java-Themen 10
G Kopie eines FileReader Allgemeine Java-Themen 4
Z Echte Kopie eines Objektes erstellen Allgemeine Java-Themen 12
O Text aus einer Textdatei rausholen, der zwischen zwei Schlüsselworten steht Allgemeine Java-Themen 4
V Umgang mit fehlenden Daten in einer Java-Datenanalyseanwendung Allgemeine Java-Themen 5
M Methodenübersicht einer Klasse einsehen Allgemeine Java-Themen 14
T JNA, Aufruf der Funktionen einer dll Allgemeine Java-Themen 5
I Vom Monolith zu Services in einer Webseite Allgemeine Java-Themen 1
W Variable Initialisierung mit dem Ergebnis einer Regex Allgemeine Java-Themen 1
O Werte einer Generic LinkedList zusammenrechenen Allgemeine Java-Themen 14
C Sortieren und Selektieren einer ArrayList<Point3D> Allgemeine Java-Themen 6
A Einzelne Objekte und Unterobjekte einer ArrayList ausgeben Allgemeine Java-Themen 53
TheSepp Wie kann man Leerzeichen aus einer Array liste entfernen? Allgemeine Java-Themen 10
B Ein Objekt einer Klasse mehreren anderen Klassen zur Verfügung stellen? Allgemeine Java-Themen 6
M Optimierung einer Methode (byte-Geraffel) Allgemeine Java-Themen 2
I Wie kann ich den Wert aus einer If abfrage ausgeben Allgemeine Java-Themen 23
S HTML einer Webseite 1:1 so bekommen wie es auch der Browser anzeigt? Allgemeine Java-Themen 14
melaniemueller Einzelne Zeile aus einer txt Datei in einem String speichern Allgemeine Java-Themen 12
L Java überprüfen lassen, ob sich ein gegebener Pfad / das Programm an sich auf einer CD oder Festplatte befindet Allgemeine Java-Themen 14
J (Geplante) Änderungen an einer Datei vorübergehend speichern und anwenden? Allgemeine Java-Themen 12
ME2002 Fragen aus einer Java Klausur Allgemeine Java-Themen 67
_user_q Obfuscate einer .jar-Datei mit ProGuard? Allgemeine Java-Themen 2
_user_q Verknüpfung einer .jar-Datei (liegt z. B. auf dem Desktop) im Autostart-Ordner erstellen? Allgemeine Java-Themen 20
C Parsen einer sich updatenden Html mithilfe von jsoup Allgemeine Java-Themen 4
E Eine Methode einer extendeten Klasse deakitivieren Allgemeine Java-Themen 12
H Performance einer Monte-Carlo-Simulation verbessern Allgemeine Java-Themen 6
LimDul Kam eine java.net.URL zu einer HashMap und ging als DNS Anfrage wieder heraus Allgemeine Java-Themen 18
E Variablen Nach Übergabe einer Variable den Constructor aufrufen Allgemeine Java-Themen 16
Zeppi NullPointerException in einer if-Abfrage Allgemeine Java-Themen 6
D Abbruch einer ViewScoped Bean in Arbeit Allgemeine Java-Themen 2
Lukas2904 Schleife mit ansteuerung einer Klasse Allgemeine Java-Themen 5
d.lumpi Aus Einer Klasse auf ein Objekt einer anderen Klasse Zugreifen Allgemeine Java-Themen 1
Lukas2904 Wie kann man cps (ClicksPerSecond) in einer GUI anzeigen lassen? Allgemeine Java-Themen 4
O Produziert das Tool "jpackage" (ab JDK 14) .exe Dateien, die auf einer Zielumgebung ohne JRE lauffähig sind ?` Allgemeine Java-Themen 7
R Lambda Expression in einer Methode execute() aufrufen (execute() ist eine Methode aus dem funktionalen Interface Command) Allgemeine Java-Themen 5
Drachenbauer wie kann ich alle instanzen einer Klasse durchsehen, ohne, dass diese in einer Liste erzeugt wurden? Allgemeine Java-Themen 11
N BlueJ Implementation einer Analoguhr Allgemeine Java-Themen 0
O Formatierte String ausgabe bei vier Variablen in einer Zeile Allgemeine Java-Themen 1
N Speicherort einer Datei im Explorer ändern Allgemeine Java-Themen 8
O Datentypen Wie kann ich den Typ einer ArrayList abfragen ? Allgemeine Java-Themen 7
O Leerzeichen und Umlaute im Pfad einer Java Applikation machen Probleme Allgemeine Java-Themen 13
H Mehrere PNG-Files in einer Datei Allgemeine Java-Themen 9
G Java Editor Löschen doppelter Zahlen einer Liste Allgemeine Java-Themen 2
J JSON Daten von einer Webseite erhalten Allgemeine Java-Themen 2
L RegEx für Teile einer Berechnung Allgemeine Java-Themen 14
L Erste Schritte TDD testen einer Methode mit injezierten Services? Allgemeine Java-Themen 12
J Zerlegen einer Zahl Allgemeine Java-Themen 6
Zrebna Wie kann man endgültig aus einer Rekursion ausbrechen? Allgemeine Java-Themen 14
MiMa Person in einer Arraylist hinzugügen mit Prüfung ? Allgemeine Java-Themen 6
Meeresgott Effizientester Weg um nach der Value einer verschachtelten Map aufzulösen Allgemeine Java-Themen 5
H Mehrere Datentypen in einer Arraylist speichern Allgemeine Java-Themen 9
MiMa Prüfziffer einer EAN Nummer berechnen Allgemeine Java-Themen 4
MiMa Erstellungsdatum einer Datei Allgemeine Java-Themen 10
Drachenbauer Wie kann ich einer existierenden Enum von außerhalb veränderte Werte zuweisen? Allgemeine Java-Themen 5
S HTML den ich von einer URL hole nicht identisch mit dem HTML im Browser Allgemeine Java-Themen 1
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
O Java-Applikation tut in Netbeans, als JAR nicht, wegen Pfadangaben einer benötigten Datei Allgemeine Java-Themen 8
M Hilfe bei einer Java Programmieraufgabe! Ab morgen Montag um 08:00 Uhr Allgemeine Java-Themen 5
J Algorithmen Analyse einer Schleife Allgemeine Java-Themen 6
Drachenbauer Wie finde ich den Aufrufer zu einer Methode, die sich nicht in meinem Projekt befindet? Allgemeine Java-Themen 2
J Die Letzte Zahl aus einer Text datei lesen Allgemeine Java-Themen 8
P einen public <Optinal String> in einer anderen Klasse mit einem Int vergleichen Allgemeine Java-Themen 2
A Mithilfe von einer Nummer einen Namen finden n-Beziehung Allgemeine Java-Themen 8
Scream_ilias Auf einer Website die anmeldedaten eingeben Allgemeine Java-Themen 9
V Threads Probleme beim Aufrufen von Methoden einer anderen Klasse (Threads) Allgemeine Java-Themen 14
I Lohnt sich heutzutage der Aufwand einer Portierung für MacOS Allgemeine Java-Themen 8
J Suchen von einer Scannereingabe in einem HashSet Allgemeine Java-Themen 1
M Konstruktor einer Methode Allgemeine Java-Themen 35
L Echtzeitdaten aus einer Webseite ziehen mit Java Allgemeine Java-Themen 19
V EMail, Attachments auslesen von einer Email Allgemeine Java-Themen 0
T Google Links in einer Liste Allgemeine Java-Themen 4
T Sinn einer toString Methode Allgemeine Java-Themen 3
P Durchlaufen einer Queue Allgemeine Java-Themen 9
J Größe einer CD ermitteln Allgemeine Java-Themen 10
L Operatoren Java Reflections: Alle Methoden einer Klasse aufrufen ohne Exceptions Allgemeine Java-Themen 5
H Länge einer verketteten Liste Allgemeine Java-Themen 4
B Quellcode einer Java libary finden um zu copy & paste'n Allgemeine Java-Themen 5
N Daten einer JCoTable in JTextArea anzeigen Allgemeine Java-Themen 7
sascha-sphw Java 9 module Zugriff auf eine resource einer anderen JAR Allgemeine Java-Themen 0
N Generic Type einer Generischen Klasse während der Laufzeit bekommen Allgemeine Java-Themen 2
E Erstellen einer Liste mit einer maximalen Menge an Elementen Allgemeine Java-Themen 13
M Wie kann ich ein int[] Array in einer Methode benutzen? Allgemeine Java-Themen 6
T Compiler-Fehler NoClassDefFoundError beim Laden einer Class Allgemeine Java-Themen 11
H Klassen LibGDX - Verschiedene Klassen als Value in einer Map Allgemeine Java-Themen 8
P Element einer Liste wurde hinzugefügt, aber es gibt keinen Zugriff Allgemeine Java-Themen 2
E Elemente innerhalb einer ArrayList vergleichen Allgemeine Java-Themen 33
J Einen Thread in einer Schleife Allgemeine Java-Themen 2

Ähnliche Java Themen

Neue Themen


Oben