![]() |
statisches Array in der Unit festlegen
Hi,
ich habe in einer Klasse mehrere hundert Methoden die für einen bestimmten Stringwert aufgerufen werden müssen. Mein Code der execute() procedure sieht daher so aus:
Delphi-Quellcode:
Jetzt ist das meiner Meinung nach viel zu komplex, d.h. wenn der Parametername XYZ kommt, muss dieser IF-ELSE-Block bis zum Schluss abgearbeitet werden.
...
else if Name = '• Adressen' then begin self.genAdressen(PromptValues); end else if Name = '• Adress-Kategorien' then begin self.genADKategorien(PromptValues); end else if Name = '• Objekte' then begin self.genObjekte(PromptValues); end ... Gibts nicht die Möglichkeit innerhalb der Unit statisch schonmal irgendeine Datenstruktur definiert um zu sagen: "Adressen" => genAdressen "Objekte" => genObjekte usw.. Natürlich könnte man sowas denke ich recht einfach zur Laufzeit erstellen, also irgendeinen Container der als Key einen string und als Value einen Methodenzeiger abspeichert. Aber da das dann immer zur Laufzeit erst generiert werden muss dachte es wäre wohl sinnvoller sowas schon statisch festlegen. |
Re: statisches Array in der Unit festlegen
Du müsstest aber das Array trotzdem durchlaufen und im ungünstigsten Fall findest du wieder erst am Ende deinen String.
|
Re: statisches Array in der Unit festlegen
Naja, das sollte dann schon eine SortedMap oder HashMap doer was auch immer sein, so dass man Keys schnell auf Values (in dem Fall die Methoden) auflösen kann.
|
Re: statisches Array in der Unit festlegen
Theoretisch könnte man sich ein Konstanten-Array folgender Art vorstellen:
Delphi-Quellcode:
Das scheitert aber daran, dass self zur Compiletime unbekannt ist :-(
TMethodEntry = Record
MName : string; // Name unter der die Methode registriert ist MAddr : TMethod; // Adresse (und self-Pointer) der Methode end; const MethodList:array[1..100] of TMethodEntry = ( ( MName :'Methode1'; MAddr :@self.Methode1 ), ... Du könntest aber die Methoden in den Abschnitt Published setzen. Dann kann man per RTTI die Methoden per Namen (als String) aufrufen. Variable Argumente sind dann aber trotzdem ein Problem, da ja je nach Anzahl und Typ der Argumente andere Werte auf den Stack müssen. |
Re: statisches Array in der Unit festlegen
Wie du das mit der Sortierung machst, weiß ich nicht, aber anlegen kannst du es so:
Delphi-Quellcode:
Jetzt brauchst du noch eine Zuordnung von Zahlen zu Methoden. Dies bietet sich über dynamische Methoden an. Leider erlaubt es der Delphi-compiler nicht direkt Nummern zu vergeben für dynamsiche Methoden. Ausßnahme sind Methoden für die Messageverarbeitung. Und so könnten wir rangehen:
type TElement=record
Key:string; Value:Integer; end; const cMethodList:array[1..3] of TElement=( (Key:'Meth1'; Value:1), (Key:'Meth2'; Value:2), (Key:'Meth3'; Value:3) );
Delphi-Quellcode:
Ist ein bisschen Umständlich und dürfte nur bei TControls so einfach mit perform klappen. Ansonsten geht es aber auch.
const Base=WM_User;
type myClass=class procedure Meth1(var msg:TMessage); message Base+1; procedure Meth2(var msg:TMessage); message Base+2; ... //Aufruf dann innerhalb der Klasse über: perform(Base+cMethodList[gefunden].Value,param1,param2); //in param1 kannst du einen übergabeparameter verstecken Mir fällt noch etwas anderes ein. Du gehst einfach über die Methdoe Methodaddress. Das ist noch kürzer und erfordert keine Liste. Es erfordert nur, dass die Methoden published sind. Dann kannst du die Methoden aufrufen. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 23:22 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz