AGB  ·  Datenschutz  ·  Impressum  







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

Design Problem (Shapes)

Ein Thema von Bjoerk · begonnen am 15. Apr 2014 · letzter Beitrag vom 15. Apr 2014
Antwort Antwort
Bjoerk

Registriert seit: 28. Feb 2011
Ort: Mannheim
1.384 Beiträge
 
Delphi 10.4 Sydney
 
#1

Design Problem (Shapes)

  Alt 15. Apr 2014, 09:39
Ich hab ein Design Problem. Ich hab 44 Typen von Shapes. Aus den 44 werden wohl mal im Laufe der Zeit mal 144 werden. Ich hab zwei Varianten des Quellcodes. Einmal als separate Klassen mit override Methoden und einmal alles in einer Klasse. Beides ist irgendwie Mist weil beides ziemlich unübersichtlich. Liegt das in der Natur der Sache oder gibt’s generell auch noch andere Möglichkeiten diesen Quellcode aufzusetzen?
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.086 Beiträge
 
Delphi 12 Athens
 
#2

AW: Design Problem (Shapes)

  Alt 15. Apr 2014, 09:56
Das kommt ganz auf deine Anforderungen an, die wir aber jetzt nicht kennen.

Eventuell bietet sich hier auch das Strategy-Pattern an. Ein Beispiel kann ich aber ohne weitere Code-Kenntnis schlecht geben.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Bjoerk

Registriert seit: 28. Feb 2011
Ort: Mannheim
1.384 Beiträge
 
Delphi 10.4 Sydney
 
#3

AW: Design Problem (Shapes)

  Alt 15. Apr 2014, 10:38
Von der Struktur her so:

Delphi-Quellcode:
type
  TBaseObject = class
  protected
    vars;
    getter, setter; virtual;
  public
    methods; virtual;
    methods; virtual; abstract;
    properties;
  end;


  TObject1..N = class(TBaseObject)
  private
    more vars;
  protected
    more vars;
    more getter, setter;
    getter, setter; override;
  public
    methods;
    methods; override;
    properties;
  end;
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.086 Beiträge
 
Delphi 12 Athens
 
#4

AW: Design Problem (Shapes)

  Alt 15. Apr 2014, 12:40
Da sich das Verhalten der 44-144 Shapes per Definition unterscheidet, kommst du um eine entsprechende Menge Code nicht herum. Das jetzt alles in eine Klasse zu packen widerstrebt mir persönlich schon sehr, ist aber durchaus ein möglicher Ansatz. Einzelne Klassen mit einer passenden Vererbungshierarchie sind mir da schon lieber - aber das ist meine persönliche Meinung.

Wenn du allerdings feststellst, daß du wiederkehrende oder ähnliche Code-Teile hast, sollte man über einen besseren Ansatz nachdenken. Da fallen mir spontan noch Anonyme Methoden und Generics ein, aber für einen fundierten Rat müsste man schon mehr sehen.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#5

AW: Design Problem (Shapes)

  Alt 15. Apr 2014, 13:42
Du kannst deine 144 Shapes ruhig so umsetzen, solltest Du sogar, wenn Du OOP machen willst.

Um elegant das richtige Shape zu instantiieren, bietet sich eine Factory an. Entweder haben die Klassen alle irgend einen Namen/Enum-Wert, oder du kannst sie klassifizieren. Mögliche Schnittstelle der ShapeFactory:

Delphi-Quellcode:
myShape := ShapeFactory.Create(shapeBigCircle); // via Enum
myShape := ShapeFactory.Create(TBigCircle); // by class, fast so wie direktes Create, aber mit mehr Möglichkeiten

// oder vielleicht mit einer ShapeFactoryFactory:
myFactory := ShapeFactoryFactory.CreateFactory(shapesCircles);
myShape := myFactory.Create(circleBig);
Ordnung bringt hier im Übrigen nur eine stringente Nomenklatur und Dokumentation. Mit einer Factory hast Du eine Dokumentation geschaffen, denn alle Shapes sind zentral (in der Factory) erfasst. Dort lässt sich auch die Nomenklatur überprüfen, einfach, weil in der Registrierung ja eh alle Namen stehen und da fällt es schon auf, wenn man bei der Benennung der Klassen geschludert hat.
Delphi-Quellcode:
Procedure TShapeFactory.Register;
Begin
  RegisterShape (TBigCircle, shapesBigCircle);
  RegisterShape (TKleinerKreis, shapesSmallCircle); // <-- Möööp
...

Geändert von Dejan Vu (15. Apr 2014 um 13:45 Uhr)
  Mit Zitat antworten Zitat
Bjoerk

Registriert seit: 28. Feb 2011
Ort: Mannheim
1.384 Beiträge
 
Delphi 10.4 Sydney
 
#6

AW: Design Problem (Shapes)

  Alt 15. Apr 2014, 14:55
Ok. Tanx. Von Factorys hab ich keinen Plan? Anonyme Methoden und Generics sind halt auch etwas ungünstig bei D2007.

Wenn das TShape von Delphi nicht 6 sondern 60 Typen hätte, wie wäre das denn programmiert worden, wenn man eine ellenlange Paint hätte vermeiden wollen und auch nicht 60 verschiedene Klassen hätte haben wollen?

Delphi-Quellcode:
procedure TShape.Paint;
begin
  case FTyp of
    Typ1:

    Typ2:

    Typ3:

    Typ4:

    Typ5:

    ..

    TypN:
  end;
end;
  Mit Zitat antworten Zitat
Antwort Antwort


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 07:06 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