AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Algorithmen, Datenstrukturen und Klassendesign Delphi Warum Strategy Pattern nicht über Metaklassen?
Thema durchsuchen
Ansicht
Themen-Optionen

Warum Strategy Pattern nicht über Metaklassen?

Ein Thema von Der schöne Günther · begonnen am 23. Jul 2013 · letzter Beitrag vom 24. Jul 2013
Antwort Antwort
Der schöne Günther

Registriert seit: 6. Mär 2013
6.155 Beiträge
 
Delphi 10 Seattle Enterprise
 
#1

Warum Strategy Pattern nicht über Metaklassen?

  Alt 23. Jul 2013, 15:10
Metaklassen. Ich wette mit diesem Wort mache ich jede Marketingabteilung schwach.

Zum Thema: Ich blättere durch ein paar Delphi-Implementationen des Strategy Patterns. Beispielsweise auf

(Wenn ich mich nicht irre bedient sich letztes dem Enten-Beispiel aus dem Head First Design Patterns-Buch )

Jetzt geht es natürlich eigentlich ums grundlegende Prinzip, aber ich wundere mich, warum jeder immer jedes Objekt eine neue Instanz einer Strategie aggregieren lässt? Grade Delphi bietet doch eigentlich schön die Möglichkeit, auf die Klasse einer Strategie, und nicht auf eine speziell erstellte Instanz einer Strategie zeigen zu lassen? Ich hätte das jetzt als "typisch Delphi" empfunden, wenn ich das nach so kurzer Zeit schon sagen darf.

Sicher ist das über Instanzen keine schlechtere Methode (sogar deutlich flexibler)- Meine Frage eher: Gibt es einen Grund, es nicht bsp. so zu tun (dummes Beispiel, wie immer)?

Delphi-Quellcode:
   TMyData = class;

   // Das sollte ein Interface sein...
   TMyDataFilterAbstract = class abstract
      class function getFilteredResult(dataIn: TMyData = nil): TMyData; virtual; abstract;
   end;

   TMyDataFilterMalZwei = class(TMyDataFilterAbstract)
      class function getFilteredResult(dataIn: TMyData): TMyData; override;
   end;

   TMyDataFilterPlusDrei = class(TMyDataFilterAbstract)
      class function getFilteredResult(dataIn: TMyData): TMyData; override;
   end;

   TMyData = class(TList<Single>)
      type
         TFilterClass = class of TMyDataFilterAbstract;
      private const
         defaultFilter: TFilterClass = TMyDataFilterMalZwei;
      public
         function getFiltered(filterType: TFilterClass = nil): TMyData;
   end;
Ähnlich auch das C++-Beispiel auf Wikipedia. Das dortige Java-Beispiel geht wieder den Weg über Instanzen.


Gibt es leidenschaftliche Meinungen zum Thema?
  Mit Zitat antworten Zitat
Benutzerbild von Meflin
Meflin

Registriert seit: 21. Aug 2003
4.856 Beiträge
 
#2

AW: Warum Strategy Pattern nicht über Metaklassen?

  Alt 23. Jul 2013, 15:51
Ganz einfach: eine nicht-trivale Strategie kann ja auch schnell mal eigenen, internen Zustand haben. Da fährst du mit deinem statischen Ansatz ganz schnell gegen die Wand. Wenn du das ganze also von der Architektur her schon so aufbaust, wirst du nie eine (in diesem Sinne) nicht-triviale Strategie implementieren können. Was du aber vorher eher nicht abschätzen kannst, ob du das nicht doch mal willst. Gegenfrage: was soll der Vorteil der statischen Variante sein?

Mit Metaklassen hat das übrigens nix zu tun. Metaklasse wäre die Klasse, von der deine Klassendefinition eine Instanz ist. Sowas gibts aber in Delphi afair überhauptnicht.
Leo S.
  Mit Zitat antworten Zitat
Benutzerbild von uligerhardt
uligerhardt

Registriert seit: 19. Aug 2004
Ort: Hof/Saale
1.746 Beiträge
 
Delphi 2007 Professional
 
#3

AW: Warum Strategy Pattern nicht über Metaklassen?

  Alt 23. Jul 2013, 16:05
Ganz einfach: eine nicht-trivale Strategie kann ja auch schnell mal eigenen, internen Zustand haben. Da fährst du mit deinem statischen Ansatz ganz schnell gegen die Wand. Wenn du das ganze also von der Architektur her schon so aufbaust, wirst du nie eine (in diesem Sinne) nicht-triviale Strategie implementieren können. Was du aber vorher eher nicht abschätzen kannst, ob du das nicht doch mal willst. Gegenfrage: was soll der Vorteil der statischen Variante sein?

Mit Metaklassen hat das übrigens nix zu tun. Metaklasse wäre die Klasse, von der deine Klassendefinition eine Instanz ist. Sowas gibts aber in Delphi afair überhauptnicht.
Also, ich hab gleich verstanden, was gemeint war.
Zitat von http://docwiki.embarcadero.com/RADStudio/XE4/en/Class_References:
A class-reference type, sometimes called a metaclass, is denoted by a construction of the form: class of type where type is any class type.
Uli Gerhardt
  Mit Zitat antworten Zitat
Der schöne Günther

Registriert seit: 6. Mär 2013
6.155 Beiträge
 
Delphi 10 Seattle Enterprise
 
#4

AW: Warum Strategy Pattern nicht über Metaklassen?

  Alt 23. Jul 2013, 16:34
Deshalb der kleine Hieb mit der Marketingabteilung - So ganz Meta ist es irgendwie nicht, aber ich habe es im Delphi-Land immer als "Metaklasse" bezeichnet gesehen.

Ich denke wohl auch zu einfach (Könnte mit der Hitze zu tun haben) - Ich hatte zu dem Zeitpunkt gerade nur Signalfilter im Kopf, da geht man einmal über einen Datensatz drüber und ist fertig. Da bekomme ich keine Probleme.

Ich glaube, ich habe bislang auch noch nie irgendein längerfristiges Vorgehen das Zustände behalten musste als Strategie ausgekoppelt - Ich habe das Problem überhaupt nicht gesehen.
  Mit Zitat antworten Zitat
Benutzerbild von Meflin
Meflin

Registriert seit: 21. Aug 2003
4.856 Beiträge
 
#5

AW: Warum Strategy Pattern nicht über Metaklassen?

  Alt 23. Jul 2013, 16:38
Stell dir zum Beipsiel vor, du implementierst Spielstrategien für Blackjack über das Strategiepattern. Dann hast du eine Strategie die zieht Random Karten bis zu einem Grenzwert (geht vllt. noch ohne Zustand). Und dann denkst du dir, du implementierst das doch besser mit der Kartenzählen-Strategie, die sich ja dann die letzten Spiele merken muss. Und das ganze noch für Multiplayer. Das geht einfach nicht, wenn deine Strategie nur statisch implementiert ist.
Leo S.
  Mit Zitat antworten Zitat
Benutzerbild von BUG
BUG

Registriert seit: 4. Dez 2003
Ort: Cottbus
2.094 Beiträge
 
#6

AW: Warum Strategy Pattern nicht über Metaklassen?

  Alt 23. Jul 2013, 21:29
Richtig interessant wird das Strategy-Pattern, wenn man die Strategie eines Objektes zur Laufzeit anpassen will.

Das passiert ganz leicht, wenn man den Benutzer zur Laufzeit das Verhalten anpassen lassen will.
Das Neu-Erstellen des Objekts ist natürlich zu teuer und entspricht auch nicht wirklich der der gewünschten Semantik.

Deine gefilterte Liste wäre ein Beispiel:
Der Nutzer soll den Filter der Liste für die Darstellung wählen können.
Da die Liste natürlich Unmengen an Daten enthält, ist das Neu-Erstellen keine Option.
Die verschiedenen darstellenden Widgets sollen von der Filterung keine Ahnung haben (warum auch).

Um es spannender zu machen: Der Filter könnte ein Aggregat aus verschiedenen Regeln sein, das der Nutzer über einen Assistenten erstellt.
Mach das mal statisch
Intellekt ist das Verstehen von Wissen. Verstehen ist der wahre Pfad zu Einsicht. Einsicht ist der Schlüssel zu allem.
  Mit Zitat antworten Zitat
Der schöne Günther

Registriert seit: 6. Mär 2013
6.155 Beiträge
 
Delphi 10 Seattle Enterprise
 
#7

AW: Warum Strategy Pattern nicht über Metaklassen?

  Alt 23. Jul 2013, 22:36
Da hätte ich mir, bei meiner Taktik, spontan eine neue Subklasse deklariert, die dann wiederum ihre von ihr aggregierten Strategien hätte kennen müssen. Ja, auf lange Sicht wäre ich nicht gut gefahren.

Wahrscheinlich hätte ich, noch von J2EE geschädigt, mir eine FilterChain-Klasse gebaut, die dann speziell dafür gut gewesen wäre und sich, mit anderen Filtern parametrisieren ließe - Großer Gott!

Manchmal bekomme ich vor mir selbst Angst, was einem bei Hitze für Gedanken im Kopf schwirren. Wo ich sitze, gibt es keine Klimaanlage


Danke für die Antworten bislang
Gut dass ich vorher gefragt habe, heut nachmittag kam mir das unheimlich attraktiv vor

Geändert von Der schöne Günther (23. Jul 2013 um 22:56 Uhr)
  Mit Zitat antworten Zitat
Furtbichler
(Gast)

n/a Beiträge
 
#8

AW: Warum Strategy Pattern nicht über Metaklassen?

  Alt 24. Jul 2013, 08:31
Nachtrag: So wie ich das sehe, ist deine Idee einfach kein Strategy-Pattern, sondern einfach eine Möglichkeit, ein konkretes Verhalten einer abgeleiteten Klasse zu definieren. Du kannst auch einfach die Filter-Methode abstrakt definieren und dann konkret implementieren. Gehüpft wie gesprungen.
  Mit Zitat antworten Zitat
Der schöne Günther

Registriert seit: 6. Mär 2013
6.155 Beiträge
 
Delphi 10 Seattle Enterprise
 
#9

AW: Warum Strategy Pattern nicht über Metaklassen?

  Alt 24. Jul 2013, 09:43
"Einmal filtern, bitte" ist vielleicht wirklich kein gutes Beispiel wenn man als Strategie gleich ein langfristiges, Zustände speicherndes Vorgehen im Kopf hat. Ich bin da wohl doch etwas einfacher gestrickt

Zu meiner Verteidigung: TDatensatz hat eine Methode "sagMirWieDuGefiltertAussiehst". Welches Verhalten da intern benutzt wird um einen gefilterten Datensatz zu erzeugen möchte ich einstellen können. Dieses delegierte Verhalten wage ich, frei nach den quakenden Enten, bereits als Strategie bezeichnen zu können.
  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 14:44 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