Frage zum Design der Datenstruktur

Status
Nicht offen für weitere Antworten.

stefan.

Mitglied
Hallo,

meine Datenstruktur sieht in etwa so aus:
Code:
Nachricht
-->Element1
-->Element1
-->Element1
-->...

--> Element2
---->Element1
---->Element1
------> Element2
-------->Element1
-------->Element1
-------->...
----->...

--> Element3
----> Element2
------->Element1
------->Element1
------->Element1
------->Element1
------->Element3
--------->Element1
--------->Element1
--------->...
------->...

Also eine Nachricht hat beliebig viele Objekte vom Typ Element 1,2 oder 3. Jedes Element kann wiederrum beliebig viele Elemente 1,2 oder 3 haben, also beliebig Schachtelbar.

Meine erste Idee ist:

Java:
public class Nachricht {
	Vector<Elementtyp> elemente;
}

public class Elementtyp {
	Element1 element1;
	Element2 element2;
	Element3 element3;
}

public class Element1{
	Vector<Elementtyp> elemente;
}

public class Element2{
	Vector<Elementtyp> elemente;
}

public class Element3{
	Vector<Elementtyp> elemente;
}

Ich würde quasi in der Klasse Elementtyp alle 3 Elemente kapseln und immer nur den jeweiligen Typ (1,2,3) setzen. Mein Gedanke dabei war, nicht immer Objekte casten zu müssen wenn ich in der Nachrichten Klasse bspw. Vector<Object> statt Vector<Elementtyp> nehmen würde.

Letztendlich muss es doch aber eine viel elegantere Methode geben ? Danke für jeden Tipp ;)
 
M

maki

Gast
Vector solltest du nicht nehmen, lieber eine "moderne" Collection wie zB. List.

Was du suchst ist das Entwurfsmuster bzw. Pattern Namens "Composite" bzw. "Kompositium", einfach mal Googlen.

Bei konkreteren Fragen kannst du diese ja stellen.
 

ARadauer

Top Contributor
Java:
import java.util.ArrayList;

public class Element {	
	ArrayList<Element> elments = new ArrayList<Element>();
}
------------
import java.util.ArrayList;

public class Nachricht {	
	ArrayList<Element> elments = new ArrayList<Element>();
}
-------
public class Nachricht1 extends Nachricht{

}
public class Nachricht2 extends Nachricht{

}
public class Nachricht3 extends Nachricht{

}
 

ARadauer

Top Contributor
lol genau verkehrt ;-=

hab jetzt Element und Nachricht verdreht, aber ich hoffe man sieht was ich meine.
deine Nachricht hat einfach eine Liste mit Elementen, ob das jetzt 1,2,3 ist ist der Nachricht egal
 
B

bygones

Gast
warum 3 Klassen fuer die Elemente ? unterscheiden die sich so dermassen ?

ansonsten wie Maki schon erwaehnt scheint das der idealfall fuers Composite pattern zu sein
 
M

maki

Gast
... und zusätzlich noch das Besucher/Visitor Pattern, falls nötig mit dem sog. Double Dispatch, dann spart man sich das casten ;)
 

stefan.

Mitglied
Also das Composite Pattern klingt interessant.

Java:
public class Nachricht {
	ArrayList<AbtsractElement> elements=new ArrayList<AbstractElement>;
}

public abstract class AbstractElement {
	ArrayList<AbstractElement> elements=new ArrayList<AbstractElement>;
	String name;
	boolean required;

	public void add(AbstractElement element){}
	public void remove(AbstractElement element){}
}

public class Element extends AbstractElement {
	public void add(AbstractElement e) {
		elements.add(e);
	}
	
	public void remove(AbstractElement e) {
		elements.remove(e);
	}
}

//entspricht Element1
public class Feld extends AbstractElement {
	int tag;
	String type;
	String value;
	int selection;
}

//entspricht Element2
public class Gruppe extends AbstractElement {
	Element element=new Element;
}

//entspricht Element3
public class Komponente extends AbstractElement {
	Element element=new Element;
}

Für eine Struktur wie
Code:
Nachricht
->Feld
->Feld
-->Gruppe
---->Feld
---->Feld
---->Komponente
------>Gruppe
-------->Feld
-------->Feld
-------->Feld
-------->...

(Eine Gruppe oder Komponente kann Felder, Gruppen oder Kompoenten enthalten, Felder enthalten jedoch keine Gruppen oder Komponenten)


Habe ich das Pattern richtig verstanden ? Wieso der Umweg über die Abstrakte Klasse ?

PS: Wusste garnicht das Vector veraltet ist. Ist denn eine ArrayList soviel Performanter ?
 
M

maki

Gast
Habe ich das Pattern richtig verstanden ? Wieso der Umweg über die Abstrakte Klasse ?
Man könnte auch ein Interface nehmen, hauptsache es gibt eine gemeinsame Schnittstelle die alle konkreten Implementierungen teilen (Feld, Gruppe, etc. pp.), so spart man sich das casten bzw. auf den Typ zu prüfen, man kann sie alle gleich behandeln, die UNterschiede sind nur noch intern, nicht mehr in der Schnittstelle.
Deswegen ist es auch besser, Methoden aller Element typen im Interface zu haben, als diese nur in bestimmten Elementen zu definieren.

Jetzt musst du dein Composite auch noch traversieren können, dazu eignet sich das Visitor Muster hervorragend.

PS: Wusste garnicht das Vector veraltet ist. Ist denn eine ArrayList soviel Performanter ?
Es geht nicht wirklich um Performance, sondernd arum dass Vector & Hashtable altlasten sind, sieh dir mal das Collection Framework an: Trail: Collections (The Java™ Tutorials)

ArrayList ist übrigens wieder eine implementierung, List ist das Interface, welches übrgigens auch von LinkedList implemnetiert wird ;)
 

stefan.

Mitglied
Hallo maki, ich habe die Klassen nochmals modifziert:

Java:
public abstract class Element implements Serializable, Visitable {

	protected List<Element> elements=new ArrayList<Element>();
	protected String name;
	protected boolean required;

	public void add(Element element){
		elements.add(element);
   }
}

public class Field extends Element {
	private int tag;
	private String type;

@Override
	public void accept(Visitor visitor) {
		visitor.visitField(this);		
	}
}

public class Group extends Element {

@Override
	public void accept(Visitor visitor) {
		if(visitor.visitGroup(this)==true){
			for (Element element : elements) {
				element.accept(visitor);
			}
		}
		visitor.leaveGroup(this);
	}
} //Component Klasse analog wie Group

public class Message extends Element {
	private String type;
	private String category;

@Override
	public void accept(Visitor visitor) {
		if(visitor.visitMessage(this) ==true){
			for (Element element : elements) {
				element.accept(visitor);
			}	
		}
	}
}

Dazu noch ein paar Fragen:

Was ist besser ? In der abstrakten Klasse (Element) bei Methoden wie add(), remove() ein default-Verhalten zu implementieren oder eine Exception zu werfen und die Methoden in den anderen Klassen (Field, Group, Component, Message,..) zu überschreiben ?

In der abstrakten Klasse habe ich eine Liste mit Elementen (List<Element>). Ein Feld (Field) benötigt so eine Liste aber nicht, wäre es nun besser diese Liste nicht in der abstrakten Klasse, sondern nur in den benötigten Klassen (Group, Component, Message) zu erstellen ?

Zusätzlich habe ich das visitor-Pattern implementiert (mit deiner Vorlage aus einem anderen Thread maki ;) :

Java:
interface Visitor: 

public interface Visitor {
	public boolean visitField(Field field);
	public boolean visitGroup(Group group);
	public boolean leaveGroup(Group group);
	public boolean visitComponent(Component component);
	public boolean leaveComponent(Component component);
	
	public boolean visitMessage(Message message);
}

interface Visitable:

public interface Visitable {
	public void accept(Visitor visitor);
}

Dazu eine Klasse PrintVisitor:

public class PrintVisitor implements Visitor {
	@Override
	public boolean visitField(Field field) {
		System.out.println("Field "+field);
	}
	//weitere Methoden des Interfaces ...
}


Nun möchte ich 2 Messages vergleichen (eine Liste von gleichen/ungleichen Feldern als Resultat).

D.h. Wenn ich das visitor Pattern richtig verstanden habe, implementiere ich einen Compare Visitor:

Java:
public class ComparatorVisitor implements Visitor {
	Message message;
	public ComparatorVisitor(Message m){
		this.message=m;
	}

	@Override
	public boolean visitField(Field field) {
		// hier alle felder der (globalen) message durchsuchen und prüfen ob field enthalten ist ?
		return false;
	}

	//weitere Methoden ..
}

Oder gibt es eine bessere (schnellere) Möglichkeit 2 Messages zu vergleichen, also nicht in jeder Methode des interfaces visitor die Message nach dem jeweiligen Element zu durchsuchen?

Danke für die Hilfe !!
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
S Noch eine Design-Frage zu Setter Allgemeine Java-Themen 6
rentasad Design-Frage - Interfaces, Klassen, statische Methoden Allgemeine Java-Themen 3
S Java Design Frage Allgemeine Java-Themen 10
M OOP Design Frage Allgemeine Java-Themen 2
Q Kapselung Allgemeine Design- Frage Allgemeine Java-Themen 8
D [Drag&Drop] Design-Pattern-Frage Allgemeine Java-Themen 4
L Design-Frage: Platzierung der Save-Methode Allgemeine Java-Themen 3
ruutaiokwu welches design pattern? frage an die oo-experten unter euch... Allgemeine Java-Themen 3
G Accordion Design Pattern Frage Allgemeine Java-Themen 2
T Design-Frage Allgemeine Java-Themen 14
S XML-Parsing / public-Member-Variablen / Design-Frage Allgemeine Java-Themen 8
N Design-Frage: persistent machen per Reflection Allgemeine Java-Themen 3
M Frage zum Design :: allgemein Allgemeine Java-Themen 6
U Frage zu DB Design Allgemeine Java-Themen 3
S design frage Allgemeine Java-Themen 10
R Design-Frage Allgemeine Java-Themen 9
KonradN Mal eine Frage zu Binary Serialization Allgemeine Java-Themen 15
8u3631984 Frage zu Java Streams min / max Allgemeine Java-Themen 17
8u3631984 Frage Performance bei Linked List und Array List Allgemeine Java-Themen 5
H Frage regex greater than less than Allgemeine Java-Themen 7
berserkerdq2 Frage zu IntelliJ und JavaFX Allgemeine Java-Themen 1
W Timer Konzept-Frage Allgemeine Java-Themen 16
T Eine Frage des Designs Allgemeine Java-Themen 2
C Frage zu eigenem TableCellRenderer Allgemeine Java-Themen 11
C Programmvorstellung & Frage zum Thema Geschäftsform Allgemeine Java-Themen 51
J Frage zu System.getproperties. Allgemeine Java-Themen 60
molat100 wie kann man die Frage beantworten Allgemeine Java-Themen 1
pkm Frage zur Präzision von Calendar.WEEK_OF_YEAR Allgemeine Java-Themen 12
J Eine Frage zu den Threads und Task Allgemeine Java-Themen 1
pkm Frage nach eventuellem syntaktischen Zucker bei der Konkatenation von ArrayLists Allgemeine Java-Themen 4
M Frage-Antwortspiel wie Wer wird Millionär Allgemeine Java-Themen 1
F Frage zu System.in Allgemeine Java-Themen 3
marcooooo Frage zum Beispiel im Anhang Allgemeine Java-Themen 16
T Meine Frage lautet wie ich 2 CSV Dateien miteinander in Java verbinde und Spalten die zueinander gehören durch den gleichen Key zusammen ausgebe? Allgemeine Java-Themen 5
B For-Loop Frage Allgemeine Java-Themen 21
L Java frage Allgemeine Java-Themen 3
bueseb84 Frage zu Mock und UpperBound Allgemeine Java-Themen 2
M Frage zum Konstruktor Allgemeine Java-Themen 2
W Best Practice Frage zur Umsetzung MVC Allgemeine Java-Themen 9
P String-Verschlüsselung - Frage zur Sicherheit Allgemeine Java-Themen 21
B Frage zu Unit-Tests Allgemeine Java-Themen 6
T Allgemeine Frage: GUI für 3D-Visualisierung Allgemeine Java-Themen 5
R Allgemeine Frage zu RMI bei MVC Allgemeine Java-Themen 2
O Frage zum Runtimeverhalten von Java ... Allgemeine Java-Themen 2
H Rundreise frage (Algorithmus) Allgemeine Java-Themen 18
B Generelle Frage bei einer Webanwendung / Reduzierung von DB Abfragen Allgemeine Java-Themen 1
D Frage zu Vererbung Allgemeine Java-Themen 5
J Frage zu regulärem Ausdruck Allgemeine Java-Themen 2
M Allgemeine Frage: Wie lernt man Java / Programmieren von Grund auf? Allgemeine Java-Themen 7
S Frage zur JLS Allgemeine Java-Themen 0
J Verständnis Frage zur Instanz, Objekte, Instanzierung, Referenz Allgemeine Java-Themen 14
A Methoden Allgemeine Java Frage Allgemeine Java-Themen 3
E String Frage Allgemeine Java-Themen 9
I bin neu bei GitHub, Frage zur Sicherheit Allgemeine Java-Themen 14
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
C KeyListener Frage Allgemeine Java-Themen 3
T Frage zu UML in Java programmieren Allgemeine Java-Themen 1
R Konstanten initialisieren - FRAGE Allgemeine Java-Themen 3
MTJ004 FTP Frage zu FTP Speicherung Java-Android-FTP Allgemeine Java-Themen 5
J Frage zum Entwurf / json-Datenmodell Allgemeine Java-Themen 8
A Frage zu meinem Code Allgemeine Java-Themen 2
RalleYTN Classpath Nur ne kleine Frage zur MANIFEST.MF Allgemeine Java-Themen 4
T Frage zu Access Modifiers Allgemeine Java-Themen 6
W Input/Output Frage zu pdfbox und FileUtils Allgemeine Java-Themen 2
O Frage zur Implementierungsweise Allgemeine Java-Themen 4
B Frage zu Bitshift Allgemeine Java-Themen 3
J Java Zufallsgenerator (6 aus 49) Frage Allgemeine Java-Themen 7
L Frage zu RIA und GWT Allgemeine Java-Themen 0
P Concurrency Frage Allgemeine Java-Themen 8
M Frage zu Enumerations Allgemeine Java-Themen 2
F Unlimited Strength Policy. Frage Verbreitung der Anwendung Allgemeine Java-Themen 1
F Frage zur Library JTS Allgemeine Java-Themen 5
E Reflection? Frage Allgemeine Java-Themen 4
C FileInputStream frage Allgemeine Java-Themen 6
G Polymorphie Programmdesign Frage Allgemeine Java-Themen 20
Uzi21 Frage zu NetBeans ( Console) Allgemeine Java-Themen 11
D Classpath Frage zum Java Resource Loading Allgemeine Java-Themen 2
G Frage zu JPA Allgemeine Java-Themen 1
S Methoden Frage Allgemeine Java-Themen 2
P MVC - Frage zu Model Allgemeine Java-Themen 4
K Frage zu Locks Allgemeine Java-Themen 1
S Frage zu abstract Allgemeine Java-Themen 5
M ArrayList<String> Frage Allgemeine Java-Themen 7
N Frage zur while-Schleife Allgemeine Java-Themen 18
T Best Practice Auslesen von Zeichenketten (Frage, Antworten, usw) Allgemeine Java-Themen 4
C Eine Frage zur Bearbeitungszeit Allgemeine Java-Themen 8
H Frage wegen Heap-Speicher Allgemeine Java-Themen 2
T Garbage Collection Frage Allgemeine Java-Themen 15
P Kurze Frage: aus einer File die Zeilenanzahl auslesen Allgemeine Java-Themen 9
D Frage zu Java und Umlauten / charsets Allgemeine Java-Themen 2
B Frage zu Java und OpenGL? Allgemeine Java-Themen 3
A eine test thread.join() frage Allgemeine Java-Themen 2
DStrohma LayoutManager Frage zum GridBagLayout Allgemeine Java-Themen 4
F Frage zu Regex möglich Allgemeine Java-Themen 4
H XML-File mit Java erzeugt Frage Allgemeine Java-Themen 10
D Frage und Antwort Programm, Problem bei Methodenaufruf Allgemeine Java-Themen 3
J NetBeans Frage bezüglich der Scanner-Klasse Allgemeine Java-Themen 6
H Java Vector Frage Allgemeine Java-Themen 9
W Frage... Allgemeine Java-Themen 29
R Frage zur topologischen Sortierung Allgemeine Java-Themen 2

Ähnliche Java Themen

Neue Themen


Oben