AGB  ·  Datenschutz  ·  Impressum  







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

Generic und Wildcards

Ein Thema von QStorm · begonnen am 10. Aug 2012 · letzter Beitrag vom 10. Aug 2012
Antwort Antwort
QStorm

Registriert seit: 28. Jun 2008
46 Beiträge
 
#1

Generic und Wildcards

  Alt 10. Aug 2012, 09:34
Hallo,

Gibt es in Delphi die Möglichkeit Platzhalter (Wildcards) anstelle von konkreten Typen bei der Erzeugung eines generischen Typen zu benutzen?

Von Java kenne ich folgendes:
Code:
ArrayList<Task<?>> entries = new ArrayList<Task<?>>();
Wobei Task irgendeine generische Klasse ist.

Nun suche ich etwas äquivalentes in Delphi:
Code:
Entries : TList<Task<?>>;
Vielen Dank im voraus.

/QStorm
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Generic und Wildcards

  Alt 10. Aug 2012, 09:46
Nein, da in Delphi eine strikte Typprüfung vorherscht, mußt du den Typen, bei Verwendung, auch vollständig deklarieren.

Task<TAbc> und Task<TXyz> sind zwei vollkommen unterschiedliche Typen, welche auch nicht miteinander kompatibel sind.


Was du machen kannst, sind generische Funktionen.

Delphi-Quellcode:
type
  TMyList = class(TList) // oder TMyList<X> = class(TList<X>)
    function SetValue<T>(const Value: T);
    procedure GetValue<T>: T;
  end;
Ob sowas auch geht, weiß ich noch nicht property Value<T>: T read GetValue<T> write SetValue<T>; (vergessen zu testen).
$2B or not $2B

Geändert von himitsu (10. Aug 2012 um 09:51 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von s.h.a.r.k
s.h.a.r.k

Registriert seit: 26. Mai 2004
3.159 Beiträge
 
#3

AW: Generic und Wildcards

  Alt 10. Aug 2012, 09:46
Wüsste nicht, dass es sowas gibt. Aber wo ist das Problem folgendes zu definiern?
Delphi-Quellcode:
type
TMyGenericList<InnerType> = TList<TList<InnerType>>;
Oder habe ich den Sinn des ? falsch verstanden?
»Remember, the future maintainer is the person you should be writing code for, not the compiler.« (Nick Hodges)
  Mit Zitat antworten Zitat
Iwo Asnet

Registriert seit: 11. Jun 2011
313 Beiträge
 
#4

AW: Generic und Wildcards

  Alt 10. Aug 2012, 10:36
Meine Erfahrung zeigt: Wenn man mit Generics anfängt, muss man das gnadenlos durchziehen, d.h. entweder mit Metaklassen arbeiten oder mit Generics. Die Programmierparadigmen beider Systeme widersprechen sich: Bei Generics will ich vorher wissen, mit wem ich es zu tun habe, bei Metaklassen nicht.

Du könntest es über ein Interface versuchen: In C# geht sowas:
Code:
private IList CreateGenericList(Type listItemType)
{
   Type listType = typeof (List<>);
   Type combinedType = listType.MakeGenericType(listItemType);
   return (IList) Activator.CreateInstance(combinedType);
}
Vielleicht (vermutlich) kann man das auch in Delphi nachbilden.
  Mit Zitat antworten Zitat
Elvis

Registriert seit: 25. Nov 2005
Ort: München
1.909 Beiträge
 
Delphi 2010 Professional
 
#5

AW: Generic und Wildcards

  Alt 10. Aug 2012, 14:42
In Java geht das, weil Java, als Runtime, gar keine Generics hat.
Der Java-Compiler benutzt eine gleichnamige Klasse ohne Typenparameter und casted sich überall einen Wolf.

Wenn du es auf einen Nenner runterbringen willst, dann nur über eine Liste eines nicht-generischen Vorfahren oder Interfaces.

Seit D2010 (?) kann Delphi ein bissel RTTI, und seitdem kann man auch verschiedene Typen in einen Typen verallgeimeinern: TValue

Hier ist mal ein Beispiel, falls ich mich nicht klar ausdrücken konnte...
Delphi-Quellcode:
type
  TTask = class abstract
  protected
    function GetValue : TValue; virtual; abstract;
  public
    property Value : TValue read GetValue;
  end;

  TTask<T> = class(TTask)
  private
    FValue: T;
    procedure SetValue(const Value: T);
  protected
    function GetValue : TValue; override;
  public
    property Value : T read FValue write SetValue;
    constructor Create(value : T);
end;

constructor TTask<T>.Create(value: T);
begin
  FValue := value;
end;

function TTask<T>.GetValue: TValue;
begin
  result := TValue.From<T>(Value);
end;

procedure TTask<T>.SetValue(const Value: T);
begin
  FValue := Value;
end;

var
  tasks : TList<TTask>;
  task : TTask;
begin
  tasks := TList<TTask>.Create();
  tasks.Add(TTask<Integer>.Create(1));
  tasks.Add(TTask<String>.Create('Hallo'));
  tasks.Add(TTask<Double>.Create(1.2345));

  for task in tasks do
    Writeln(task.Value.ToString());
end.
Robert Giesecke
I’m a great believer in “Occam’s Razor,” the principle which says:
“If you say something complicated, I’ll slit your throat.”
  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 00:37 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