AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Designfrage: Pest oder Cholera

Ein Thema von Patrick · begonnen am 22. Jun 2011 · letzter Beitrag vom 23. Jun 2011
Antwort Antwort
Seite 1 von 3  1 23      
Patrick

Registriert seit: 15. Sep 2003
184 Beiträge
 
Delphi 2010 Professional
 
#1

Designfrage: Pest oder Cholera

  Alt 22. Jun 2011, 14:01
Ich habe da mal ne Designfrage: Auf diese Unschönheit bin ich jetzt schon öfter gestoßen:

Und zwar habe ich ein paar Basisklassen:
z.B. THaus, TGarten und TGarage. (Können auch mehr sein, die in Beziehung zueinander stehen (auch Vererbung).

Jetzt haben alle Klassen etwas gemeinsam:
Ich kann sie (oder Besser die Daten, die sie enthalten) z.B. als XML exportierten und sie in eine Datenbank speichern. Deshalb hat jede Klasse eine Methode SaveToDataBase(Query : TQuery) und eine Methode ExportToXML(XMLAccess : TXMLAccess);

Damit weiß jede Klasse nur das, was sie wissen muss. (Es gibt keinen Datenbank-"Blob" der alle Klassen kennt und das komplette speichern übernimmt.)
Und jede Klasse gibt nur so viel preis, wie sie muss. (Wie sie in die Datenbank gespeichert wird weiß jede Klasse selbst am Besten.)

Und jetzt habe ich zwei Programme, die die Basisklassen verwenden. Programm1 benutzt die Klassen in vollem Umfang. Programm2 hat allerdings keine Datenbank-Anbindung, weshalb die Methoden SaveToDataBase keinen Sinn machen und einen TQuery kennt das Programm daher auch nicht. Wenn beide Programme aber die selben Units verwenden sollen muss ich mit hässlichen Compilerschaltern arbeiten um die Datenbank-Methoden und entsprechende Units aus der Uses-List vor Programm2 zu verstecken.

Gibt es dafür nicht ne Bessere Lösung? Stimmt mein Design nicht?
Genieße jede Minute deines Lebens, denn sie wird nicht wieder kommen.
  Mit Zitat antworten Zitat
Benutzerbild von Phoenix
Phoenix
(Moderator)

Registriert seit: 25. Jun 2002
Ort: Hausach
7.640 Beiträge
 
#2

AW: Designfrage: Pest oder Cholera

  Alt 22. Jun 2011, 14:05
Sicher aufwändig, aber machbar:

Entwerfe ein Interface IExporter und die Klassen bekommen beide nur noch eine Methode ExportTo(IExporter).

Du baust dann einen XMLExporter und einen DatabaseExporter, und nur diese beiden Klassen brauchen dann die XML-Lib bzw. die DB-Komponenten zu kennen.

Somit entkoppelst Du Deine Klassen komplett von der Persistenzschicht.
Sebastian Gingter
Phoenix - 不死鳥, Microsoft MVP, Rettungshundeführer
Über mich: Sebastian Gingter @ Thinktecture Mein Blog: https://gingter.org
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.017 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#3

AW: Designfrage: Pest oder Cholera

  Alt 22. Jun 2011, 14:09
RTTI und Attribute benutzen und deklarativ festlegen, was die Klassen exportieren.

Hier zeigt Rob, wie's geht.
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight

Geändert von Stevie (22. Jun 2011 um 14:11 Uhr)
  Mit Zitat antworten Zitat
Namenloser

Registriert seit: 7. Jun 2006
Ort: Karlsruhe
3.724 Beiträge
 
FreePascal / Lazarus
 
#4

AW: Designfrage: Pest oder Cholera

  Alt 22. Jun 2011, 14:26
Wären Class Helpers nicht eine Möglichkeit? Ansonsten fiele mir auch nix besseres ein als die Variante von Phoenix.
  Mit Zitat antworten Zitat
Benutzerbild von Phoenix
Phoenix
(Moderator)

Registriert seit: 25. Jun 2002
Ort: Hausach
7.640 Beiträge
 
#5

AW: Designfrage: Pest oder Cholera

  Alt 22. Jun 2011, 14:29
auch nix besseres ein als die Variante von Phoenix.
Als ob das ein schlechter Vorschlag wäre
Allein schon gemäß des SRP sollte eine Klasse sowieso niemals irgendwelche Logik haben UND nach XML exportieren UND in eine Datenbank schreiben. Das sind drei 'Verantwortlichkeiten' bzw. Responsibilities und daher sollten das auch auf jeden Fall drei Klassen sein
Sebastian Gingter
Phoenix - 不死鳥, Microsoft MVP, Rettungshundeführer
Über mich: Sebastian Gingter @ Thinktecture Mein Blog: https://gingter.org
  Mit Zitat antworten Zitat
Blup

Registriert seit: 7. Aug 2008
Ort: Brandenburg
1.465 Beiträge
 
Delphi 12 Athens
 
#6

AW: Designfrage: Pest oder Cholera

  Alt 23. Jun 2011, 09:17
Es bietet sich dieses Muster an: http://de.wikipedia.org/wiki/Visitor
Der Visitor kapselt ein bestimmtes Verhalten, z.B. das Speichern in eine Datenbank.

Für jede Klasse kann eine Hilfsklasse (z.B. THausDataBaseWriter) geschaffen werden,
die sowohl die Datenbank als auch die konkrete Datenklasse kennt.
Die Hilfsklasse wird beim Visitor registriert und von diesem benutzt, wenn er eine entsprechende Klasse besucht.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.624 Beiträge
 
Delphi 12 Athens
 
#7

AW: Designfrage: Pest oder Cholera

  Alt 23. Jun 2011, 09:33
Zum Visitor Pattern kann man schön bei Uwe Raabe nachlesen.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von mschaefer
mschaefer

Registriert seit: 4. Feb 2003
Ort: Hannover
2.032 Beiträge
 
Delphi 12 Athens
 
#8

AW: Designfrage: Pest oder Cholera

  Alt 23. Jun 2011, 10:28
Eigentlich ist das ein Compilerproblem. Wahrscheinlich kann man sowas nur mit MultiPassCompilern lösen.
Sonst denke ich auch, dass Phoenix einen guten Ansatz hat.
Martin Schaefer
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.079 Beiträge
 
Delphi 12 Athens
 
#9

AW: Designfrage: Pest oder Cholera

  Alt 23. Jun 2011, 10:55
Wenn es unbedingt direkt in der Klasse verfügbar sein muß, dann eben Class-Helper oder die bösen Generics.
Aber dieses Visitor-Patern, kann auch nicht schaden.

Oder einfach nur eine Vererbung:
- in der Basisklassen gibt es abstrakte Speichermethoden
- und dann in Ableitungen jeweils mit der entsprechenden Speichermethode versehen.

Visitor hat aber den Vorteil, daß du die Speicherklassen dann auch noch für andere Dinge wiederverwenden kannst.
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.

Geändert von himitsu (23. Jun 2011 um 10:57 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.079 Beiträge
 
Delphi 12 Athens
 
#10

AW: Designfrage: Pest oder Cholera

  Alt 23. Jun 2011, 10:57
[del]
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 22:42 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz