Best Practice für kleine Variationen in gegebenen Modellklassen

musiKk

Top Contributor
Hallo Forum,

ist nur eine kleine Frage. Mir geht es darum, dass verschiedene Modellklassen in verschiedenen Kontexten auch verschiedene Erweiterungen brauchen. Ein Beispiel: Ich bekomme Objekte von einem Web Service und stelle diese in einer Tabelle dar. Die Daten werden in den Spalten angezeigt und es gibt eine zusätzliche Auswahlspalte mit einer Checkbox, mit der man einzelne Zeilen aktivieren kann. Also braucht jede Zeile ein zusätzliches Attribut [c]checked[/c].

Wie würdet ihr das am besten angehen? Spontan fallen mir zwei Möglichkeiten ein:
1. Ein neues Objekt wird erstellt, welches beide Informationen enthält. In etwa
Java:
public class DataSelectIndicator {
	Data data;
	boolean selected;
}
2. Es wird vom alten Objekt geerbt und ein zusätzliches Attribut hinzugefügt:
Java:
public class SelectableData extends Data {
	boolean selected;
}

Vielleicht gibt es ja auch noch mehr. Das etwas nervige an beiden Varianten ist, dass wegen wegen solcher Kleinigkeiten immer neue Objekte erzeugt werden müssen und dann ist alles voll mit [c]ExtendedData[/c], [c]SelectableData[/c], [c]FooData[/c], ...
Vielleicht habe ich ja noch etwas offensichtliches übersehen. Vielleicht ist es ja auch Ok, nach einer der beiden Varianten vorzugehen und nur mir kommts komisch vor.

Danke schonmal
mK
 
S

SlaterB

Gast
Java:
public class SelectIndicator<T extends Data> {
    T data;
    boolean selected;
}
so zumindest nur eine Klasse bei verschiedenen Data-Arten ;)

ansonsten vielleicht etwas Richtung
DataExtension<Boolean>
DataExtension<String>
..
 
G

Gast2

Gast
Du kannst auch in Data eine Liste mit einet neuer Klassen machen z.B. AttributeValue dann kannst soviele Value dynamsich reinschmeißen und befüllen und diese dann auswerten...
 

musiKk

Top Contributor
@SlaterB
Ok, bei mir wechselt häufiger das, was in dem Beispiel [c]selected[/c] ist. Insofern könnte man das auch umgekehrt aufziehen...
Java:
public class ExtendedData<T> {
	Data data;
	T extension;
}
Tja, das ist das, was ich meine... in die Richtung habe ich gar nicht gedacht.

@SirWayne
Das wollte ich eigentlich vermeiden. Ich habe zwar mehr oder weniger Einfluss auf das Aussehen von beiden Seiten - also sowohl den Produzenten als auch den Konsumenten von Data -, aber das sollte dennoch möglichst entkoppelt sein. Schließlich kann potentiell jede Klasse eine solche Liste gebrauchen. Außerdem kann in Zukunft auch ein anderer Konsument hinzukommen (who knows...) und der braucht das vielleicht gar nicht.

Danke für die Antworten bisher.
 

musiKk

Top Contributor
Sieht interessant aus. Ich werde aber wohl bei einer der andere Lösungen bleiben. Zum einen handelt es sich um reine Modelle ohne Interfaces und das Pattern scheint mehr auf Services abzuzielen. Wichtiger ist aber zum anderen, dass die Klassen generiert werden und da ist die Implementierung eines Interfaces nicht vorgesehen.
Gerade im Zusammenhang mit Eclipse ist das aber gut zu wissen.
 

Wildcard

Top Contributor
Ich werde aber wohl bei einer der andere Lösungen bleiben. Zum einen handelt es sich um reine Modelle ohne Interfaces und das Pattern scheint mehr auf Services abzuzielen.
Nein, das hat mit Services nichts zu tun. Das Pattern lässt sich auf jede Art Klasse anwenden.
Wichtiger ist aber zum anderen, dass die Klassen generiert werden und da ist die Implementierung eines Interfaces nicht vorgesehen.
Hört sich nach dem falschen Modelling Werkzeug an. Schonmal EMF angeschaut?
 

musiKk

Top Contributor
Ich habe ein WSDL und brauche einen Service-Client (JAX-WS). Momentan wird der über [c]wsimport[/c] erzeugt. Wenn das mit EMF genauso einfach geht und mehr kann, dann von mir aus auch so, aber diesbezüglich habe ich nicht viel gefunden.

Angesehen habe ich mir das sonst aber nicht, weil Du das dermaßen oft erwähnst, dass mir die Einschätzung nicht objektiv vorkommt und wie ein goldener Hammer aussieht. Ist nicht böse gemeint, Deine restlichen Beiträge schätze ich schon. :)
 

Wildcard

Top Contributor
Ich habe ein WSDL und brauche einen Service-Client (JAX-WS). Momentan wird der über wsimport erzeugt. Wenn das mit EMF genauso einfach geht und mehr kann, dann von mir aus auch so, aber diesbezüglich habe ich nicht viel gefunden.
Für JAX-WS gibt es AFAIK keinen Build-In Support. Texo geht wohl in diese Richtung, aber da kenne ich die Details nicht.

Angesehen habe ich mir das sonst aber nicht, weil Du das dermaßen oft erwähnst, dass mir die Einschätzung nicht objektiv vorkommt und wie ein goldener Hammer aussieht. Ist nicht böse gemeint, Deine restlichen Beiträge schätze ich schon.
Das hat einen einfachen Grund, EMF hat zwar mittlerweile einen sehr hohen Verbreitungsgrad (besonders in Europa), allerdings ist es nicht so verbreitet wie es aufgrund der Funktionalität eigentlich sein sollte. Da praktische jede Software Modelle enthält und EMF derzeit der Heilige Gral des Modellings ist, sollte EMF eigentlich in ca. 90% aller Java Software zum Einsatz kommen und da fehlt noch ein Stück... ;)
 

musiKk

Top Contributor
Für JAX-WS gibt es AFAIK keinen Build-In Support. Texo geht wohl in diese Richtung, aber da kenne ich die Details nicht.

Ok, mal schauen.


Das hat einen einfachen Grund, EMF hat zwar mittlerweile einen sehr hohen Verbreitungsgrad (besonders in Europa), allerdings ist es nicht so verbreitet wie es aufgrund der Funktionalität eigentlich sein sollte. Da praktische jede Software Modelle enthält und EMF derzeit der Heilige Gral des Modellings ist, sollte EMF eigentlich in ca. 90% aller Java Software zum Einsatz kommen und da fehlt noch ein Stück... ;)

Nun gut, ich habe nur auch schon die Erfahrung gemacht, dass bedingungsloses Anpreisen schnell als "Fanboytum" abgestempelt und mit Ignoranz gestraft wird. Egal, wie die Fakten aussehen.
 

Wildcard

Top Contributor
Nun gut, ich habe nur auch schon die Erfahrung gemacht, dass bedingungsloses Anpreisen schnell als "Fanboytum" abgestempelt und mit Ignoranz gestraft wird. Egal, wie die Fakten aussehen.
Da will ich dir gar nicht widersprechen, aber wenn ich mir überlege wie viele Mannmonate Entwicklung mir EMF in zahllosen Projekten mittlerweile gesparrt hat, finde ich es nur fair etwas zu 'evangelisieren'.
EMF und das Eclipse Modelling Ökosystem sind schon lange dort angekommen wo Microsoft schon seit Jahren versucht mit Projekt Oslo hinzukommen. Der Unterschied, Microsoft streicht Oslo immer weiter zusammen während Eclipse Modelling stetig wächst.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
J Best Practice für implementierung von equals(...) Allgemeine Java-Themen 7
T Best Practice überprüfen von Übergabeparametern Allgemeine Java-Themen 17
S best practice: Einordnung Enitity und Datenklasse Allgemeine Java-Themen 11
temi best practice: Parameter überprüfen, wo? Allgemeine Java-Themen 9
Airwolf89 JUnit: Vorschläge/ Best Practice Allgemeine Java-Themen 7
M Best Practice: Daten aufnehmen-speichern-bereitstellen Allgemeine Java-Themen 8
H Best Practice zu vielen konstanten Objekten? Allgemeine Java-Themen 10
F best practice Allgemeine Java-Themen 5
J Input/Output Dateien bearbeiten - "Best Practice" Allgemeine Java-Themen 3
R Statische Klasse: Best practice mit flags (2) Allgemeine Java-Themen 3
Daniel_L Best Practice zum Löschen von Log-Files? Allgemeine Java-Themen 8
Ameise03 Best&Worst Case bei Insertionsort Allgemeine Java-Themen 10
S Best Practices CopyConstrutor mit ArrayList Allgemeine Java-Themen 1
F Error Logging - best practices? Allgemeine Java-Themen 3
M Best Practices für Undo/Redo Allgemeine Java-Themen 16
G Best Practices Software-Engineering‏ Allgemeine Java-Themen 3
G Best Practices Allgemeine Java-Themen 10
M Best Practices Exception Handling für eigene library Allgemeine Java-Themen 8
S best practise Allgemeine Java-Themen 6
S Array: Anzahl Elemente mit best. Wert zählen Allgemeine Java-Themen 4
M Best Match / Best Fit auf Strings Allgemeine Java-Themen 9
B Algorithmus für Arbeit mit fehlenden Listenelementen? Allgemeine Java-Themen 1
kodela Eingabe für TextArray bedingt sperren Allgemeine Java-Themen 3
Karl_Der_Nette_Anfänger Hat wer ne Lösung für verknüpfte Postleitzahlen? (Baum/Wurzel Struktur) Allgemeine Java-Themen 11
R 11 GB File lesen ohne zu extrahieren Filedaten Bereich für Bereich adressieren dann mit Multi-Thread id die DB importieren Allgemeine Java-Themen 3
G KeyListener für JTextField Allgemeine Java-Themen 5
webracer999 Library für Textsuche (z. B. include/exclude, and/or)? Allgemeine Java-Themen 5
I Module-Info für Jar erzeugen Allgemeine Java-Themen 7
krgewb Java-Bibliothek für ONVIF Allgemeine Java-Themen 1
B Simpler Eventlistener für Tastaturtaste bauen? Allgemeine Java-Themen 13
_user_q Eingegebenen Text Zeile für Zeile ausgeben lassen Allgemeine Java-Themen 11
E Key für TOTP Algorythmus(Google Authentificator) Allgemeine Java-Themen 0
S Formel für Sonnenwinkel in ein Programm überführen Allgemeine Java-Themen 11
M pfx-Zertifikat in Tomcat für SSL-Verschlüsselung nutzen Allgemeine Java-Themen 14
R Best Practice Erfahrungswerte für eine Migration von JSF nach Angular (oder anderes JS-Framework) Allgemeine Java-Themen 1
B HeapSort für Array of Strings funktioniert nur teilweise Allgemeine Java-Themen 3
jhCDtGVjcZGcfzug Klassen Was genau passiert hier? Kann mir das jemand bitte Zeile für Zeile erklären? Allgemeine Java-Themen 1
rosima26 Bester Sortieralgorithmus für kurze Arrays Allgemeine Java-Themen 40
S Mit Methoden kann man definieren für was <T> steht. Geht das auch irgendwie für Variablen? Allgemeine Java-Themen 12
MangoTango Operatoren while-Schleife für Potenz Allgemeine Java-Themen 3
B Lottospiel, genug Reihen tippen für 3 Richtige (Spaß mit Arrays)? Allgemeine Java-Themen 46
B Mit welchen Datentypen und Strukturierung am Besten dutzende Baccaratspiele Shcritt für Schritt durchsimulieren? Allgemeine Java-Themen 26
D Klassendesign für einen Pascal Interpreter Allgemeine Java-Themen 6
I OCR Library für Belegerkennung Allgemeine Java-Themen 7
farah GetterMathod für Farbkanäle Allgemeine Java-Themen 6
B Welcher Datentyp für sehr große Zahlenbereiche? Allgemeine Java-Themen 1
S Webservices für binäre Daten? Allgemeine Java-Themen 5
G Licence-Header für InHouse entwickelten Source Allgemeine Java-Themen 8
M Schleife für einen TicTacToe Computer Allgemeine Java-Themen 5
O git ignore für Intellji braucht es die .idea Dateien? Allgemeine Java-Themen 8
F Java Script für das Vorhaben das richtige? Allgemeine Java-Themen 9
M wiviel Java muss ich für die Berufswelt können ? Allgemeine Java-Themen 5
Robertop Datumsformat für GB ab Java 16 Allgemeine Java-Themen 1
Thallius Verschiedene entities für gleichen Code…. Allgemeine Java-Themen 8
OnDemand Zentrale "Drehscheibe" für verschiedene APIs Allgemeine Java-Themen 14
S Übergabe eines Sortierkriteriums für ein Artikel Array mittels BiPredicate<Artikel, Artikel> Allgemeine Java-Themen 13
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
D SHA-3 für Java-version 1.8 Allgemeine Java-Themen 1
N Validator für einen SQL-Befehl Allgemeine Java-Themen 22
Muatasem Hammud Erstellung von Testdaten für Arrays Allgemeine Java-Themen 6
B Logikfehlersuche, das perfekte Lottosystem für 3 Richtige mit Arraylists? Allgemeine Java-Themen 61
G Methoden für die Zukunft sinnvoll? Allgemeine Java-Themen 4
M API für PLZ Umkreissuche Allgemeine Java-Themen 3
1Spinne JDK 8 für Eclipse installieren Allgemeine Java-Themen 5
Tobero Meine Funktion für das beinhalten eines Punktes in einem Kreis funktioniert nicht Allgemeine Java-Themen 5
L Methoden Parser für gängige Datumsformate? Allgemeine Java-Themen 1
H Interface PluginSystem ClassNotFound exception für library Klassen Allgemeine Java-Themen 10
N relativier Pfad für sqlite-Datenbank in Gradle/IntelliJ Allgemeine Java-Themen 2
buchfrau Anagram für beliebiges Wort Allgemeine Java-Themen 2
TonioTec Api für Datenaustausch zwischen Client und Server Allgemeine Java-Themen 0
W Suche Ursache für NPE - woher kommt sie? (Hilfe beim Debugging) Allgemeine Java-Themen 19
Kirby.exe Distanz Map für die Distanztransformation erstellen Allgemeine Java-Themen 1
F PI Regler für Heizung Allgemeine Java-Themen 7
8u3631984 Generelle Log4j.xml für alle Module Allgemeine Java-Themen 5
M Wie übergebe ich den Zähler für die Anzahl Rekursionsschritte korrekt? Allgemeine Java-Themen 2
B Login für User, der im Hintergrund Schedules ausführt Allgemeine Java-Themen 16
L RegEx für Teile einer Berechnung Allgemeine Java-Themen 14
S Java-Task-Management-Tool für Windows und Mac selber programmieren Allgemeine Java-Themen 4
M Java 2D Array für ein Grid erstellen ? Allgemeine Java-Themen 2
Z Welches GUI Framework für Java ist aktuell? Allgemeine Java-Themen 16
N Convert.FromBase64 von C# für Java Allgemeine Java-Themen 11
N fixed-keyword von C# für Java Allgemeine Java-Themen 6
O Suche Scripter für alt:V Project! Allgemeine Java-Themen 0
S Interface Design von HookUp oder Callback Methoden für eigenes Framework Allgemeine Java-Themen 9
O Suche Unterstützung für ein OpenSource-Projekt (grafischer Editor) Allgemeine Java-Themen 13
Kirby.exe Software für Graphische Visualisierung Allgemeine Java-Themen 20
B OOP Auslöser für NullPointerException Allgemeine Java-Themen 3
L Generator für einen Parser implementieren Allgemeine Java-Themen 13
DonMalte Ambitioniertes Projekt für Einsteiger & Motivierte Allgemeine Java-Themen 0
Kirby.exe Movement System für Spiel Allgemeine Java-Themen 13
Kirby.exe Framework für Game Design Allgemeine Java-Themen 8
W Alternative für Threads Allgemeine Java-Themen 6
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
Elyt Compiler-Fehler Datei kann nicht erstellt werden. Die Syntax für den Dateinamen etc. ist falsch. Allgemeine Java-Themen 2
Thallius Rätsel für Windows Profis Allgemeine Java-Themen 8
D OOP Gemeinsamen ID-Raum für zwei Klassen implementieren Allgemeine Java-Themen 7
D Input/Output Implementierung eines CommandHandlers/Parsers für viele Eingaben Allgemeine Java-Themen 26
Thallius Alternative für SwingWorker Allgemeine Java-Themen 5
I Lohnt sich heutzutage der Aufwand einer Portierung für MacOS Allgemeine Java-Themen 8
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30

Ähnliche Java Themen

Neue Themen


Oben