![]() |
Delphi-Version: 10 Seattle
Generisches Alias von TFrame
Tut mir leid, dass ich Euch schon wieder belaestigen muss.
Ich haenge an etwas so simplem, aber die Loesung ist nicht greifbar: Ich versuche ganz einfach ein generisches Alias fuer einen Frame zu deklarieren. Nach einiger googlerei denke ich, dass ich einfach die "CreateNew" statt "Create" wie bei TForm fuer TFrame suche. Aber mal ganz von vorne:
Delphi-Quellcode:
type
TSpeziellerFrame = class(TFrame) [...] End; TKanne<TObjectList> = class( TSpeziellerFrame; ) // ohne class() kompilierts gar nicht
Delphi-Quellcode:
constructor TJodokus<T>.Create(AOwner: TComponent);
var AView: TKanne<T>; begin AView := TKanne<T>.Create(AOwner); // hier krachts: TCustomFrame.Create-> not InitInheritedComponent(Self, TFrame) -> raise EResNotFound end;
Delphi-Quellcode:
Gibt es irgendeinen legitimen Grund, warum das nicht von Natur aus funktioniert?!
begin
TJodokus<TObjectList>.Create(Self); end; Habe schon etliche Konstellationen probiert, komme aber einfach nicht drauf. Danke fuers Lesen! |
AW: Generisches Alias von TFrame
Warum das nicht läuft habe ich jetzt nicht gecheckt, aber
wäre nicht ein Interface das was du suchst statt die Klasse selbst zu speichern ?
Delphi-Quellcode:
Rollo
type
TSpeziellerFrame = class(TFrame, ISpeziellerFrame) [...] End; |
AW: Generisches Alias von TFrame
Zitat:
"Einen" Alias für mehrere Klassen kannst du so eh nicht definieren. Ob sowas
Delphi-Quellcode:
geht, also wirklich ein Alias, weiß ich jetzt nicht, oder ob man da auch
type TKanne<xxx> = TSpeziellerFrame<xxx>;
Delphi-Quellcode:
machen muß.
type TKanne<xxx> = class(TSpeziellerFrame<xxx>);
Dieser Alias
Delphi-Quellcode:
geht allerdings, aber wenn man sowas als Komponente/SubKomponente in der DFM speichern will, also auf den Formdesigner legen,
TKanne = TSpeziellerFrame<TObjectList>;
dann darf es kein Alias sein, sondern muß als neuer Typ
Delphi-Quellcode:
verpackt werden, da gültige "Bezeichner" für die Klassenverwaltung und den DFM-Reader keine < und > enthalten dürfen.
TKanne = class(TSpeziellerFrame<TObjectList>);
|
AW: Generisches Alias von TFrame
Ok, vielen Dank!
So langsam gehen mir die Delphi-Generics auf den Keks, alles muss man nachher trotzdem manuell aufbroeseln. Da kann ich auch direkt alles ausschreiben, wenns immer an exakt den Ecken haengenbleibt, an denen Generics den Code vereinfachen/verallgemeinern wuerden... vielleicht habe ich da auch nur generell eine falsche Erwartungshaltung bzgl. generics, aber ich dachte das aus anderen OO-Sprachen etwas flexibler zu kennen. |
AW: Generisches Alias von TFrame
Zitat:
Sowas wünsche ich mir für Delphi ja nach wie vor, aber ich befürchte dass wird ein Wunschtraum bleiben. |
AW: Generisches Alias von TFrame
Warum meckert er denn hier schon wieder:
Delphi-Quellcode:
In FreePascal gaebe es ja glaube ich
type
TObstKorb<T: TFrucht> = class procedure Essen; virtual; abstract; End; TBananenKorb = class(TObstKorb<TBanane>) procedure Essen; override; End; [...] begin AKorb := TObstKorb<TBanane>.Create; AKorb.Essen; // abstrakter Fehler AKorb := TBananenKorb.Create; AKorb.Essen; // funktioniert end;
Delphi-Quellcode:
. Wie deklariere ich denn die Spezialisierung in Delphi ohne sie abzuleiten?
TBananenKorb = specialize TObstKorb<TBanane>;
|
AW: Generisches Alias von TFrame
Er meckert weil AKorb ein TObstKorb<TBanane> ist und dort ist Essen abstract. Ich würde da einen Fehler erwarten.
Wozu willst du eine Spezialisierung? Ich leite immer ab wenn ich es brauche. So ganz kann ich Deine Probleme leider nicht nachvollziehen. Mich nerven die zwar auch, ab an anderen Stellen wie z.b., dass es keine contraints für Aufzählungstypen gibt. Wie verwenden gerne Generics (gerade gesucht - an insgesammt 2168 Stellen) |
AW: Generisches Alias von TFrame
Zitat:
Delphi-Quellcode:
funktionieren wuerde, koennte ich in einer generischen Funktion in Abhaengigkeit von T a la
TObstKorb<TBanane>.Create
Delphi-Quellcode:
die Generik weiterreichen. Das waere doch praktisch, oder?
constructor TProgrammModel<T>.Create;
begin Data := TObstKorb<T>.Create; end; So wie es aussieht, muss ich aber in jeder generischen Ebene dann so einen Schei*dreck wie
Delphi-Quellcode:
machen.
constructor TProgrammModel<T>.Create;
var AInfo: PTypeInfo; AInfoData: PTypeData; tkString: String; begin AInfo := System.TypeInfo(T); AInfoData := GetTypeData(AInfo); tkString := TypInfo.GetEnumName(System.TypeInfo(T), Ord(AInfoData^.OrdType)); if tkString = 'tkBanane' then AKorb := TBanenenKorb.Create else if tkString = 'tkApfel' then AKorb := TApfelKorb.Create; end; Erst so kann ich AKorb<T: TFrucht> wirklich generisch verwenden?! Und das in jeder generischen Hierarchie-Ebene? JESUS CHRIST, please kill me. Oder uebersehe ich da jetzt massiv was... |
AW: Generisches Alias von TFrame
Oder ich...
Ich wüsste jetzt woher der compiler wissen soll dass Du nicht TObstKorb<TBanane> sondern TBananenKorb haben willst. Vielleicht vergisst Du mal die Generics und beschreibst mal welches Anwender-Problem Du lösen willst. |
AW: Generisches Alias von TFrame
Zitat:
Ich habe 2 Objekt-Typen (nennen wir die Typen mal A1 und A2), die ein paar gleiche und ein paar unterschiedliche Variablen und Funktionen besitzt. Daher erben sie die allgemeinen Eigenschaften vom Typ A. Die Eigenschaften, die gleich sind (von A geerbt), werden von vielen anderen Units im Programm benoetigt und manipuliert. Das ganze Programm verwendet insgesamt nur entweder A1 oder A2, nie beide Typen. Ich habe ein Adapter-Objekt, das die meisten Manipulationen (sowohl Typ A, A1 und A2) daran vornimmt. Die anderen Units benoetigen immer nur Typ A allgemein, nie die Eigenschaften von A1 und A2. Daher hat mein Adapter einen Getter, der Typ A rausgibt, aber auch viele andere Getter, die einzelne A-Eigenschaften an andere Units rausgeben. Ich will vermeiden, dass ich 2 unterschiedliche A1 A2 im Adapter ablege, sprich vermeiden, dass ich alle Getter/Setter/etc des Adapters zwiespalten muss, obwohl nahezu identischer Code ausgefuehrt wird. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 08: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