![]() |
Re: Container-Klassen in Delphi
Du benötigst auch beim Rückgabewert keinen vollqualifizierten Typnamen, wenn der entsprechende Namespace oder Typ importiert wurde, was wohl der Fall ist, wenn du List<T> ohne Namespace-Angabe verwendest.
|
Re: Container-Klassen in Delphi
Zitat:
Denn so wie du es jetzt hast, hast du nur eine öffentliche Methode GetEnumerator und vertraust darauf, dass der Compiler anhand dieses Namens und des Rückgabewertes entscheidungen trifft. Aber ohne IEnumerable<T> gibt es kein LINQ und viele andere Dinge gehen auch nicht. Eine Containerklasse sollte in .net alle Standardinterfaces implementieren, die auf sie zutreffen. Bei dir wäre das IList<T>, welches ICollection<T> und IEnumerable<T> mitbringt. |
Re: Container-Klassen in Delphi
Zitat:
|
Re: Container-Klassen in Delphi
Zitat:
Also für alle Datencontainer. IEnumerable<T> ist eine Spezialisierung für einen bestimmten Itemtypen. "LINQ over Objects" basiert auf IEnumerable<T>, genau wie viele Methoden von vielen Hunderten von Klassen mit IEnumerable<T> umgehen können. Es nicht zu implemetnieren würde heißen, dass deine Containerklasse nur so wie in Delphi wäre: Eine weitere Klasse. Mit der Implementierung ist sie eine richtige Containerklasse, auf die du Abfragen machen kannst, die du mit einem Call an eine andere Liste anhängen kannst,... Mit meinem Beispiel oben wäre folgende LINQ-Query möglich:
Delphi-Quellcode:
var persons := new PersonList<Person>();
// irgendws hinzufügen var personNames := (from p in persons where not String.IsNullOrEmpty(p.Name) select distinct p.Name).ToList(); |
Re: Container-Klassen in Delphi
Ich habe jetzt eine aktualisierte Fassung im ersten Posting hochgeladen. Die Modifikationen der Klasse, wie sie Elvis vorschlägt sind noch nicht eingearbeitet.
|
Re: Container-Klassen in Delphi
Zitat:
Ich sehe gerade, Luckie, dass du fast genauso wie ich es vorgeschlagen habe, hast du es umgesetzt. :mrgreen: MfG xZise |
Re: Container-Klassen in Delphi
Sorry wenn das jetzt hier leicht OT wird,
aber ich bin soeben ueber den Konstrukt
Delphi-Quellcode:
gestolpert.
type
PersonList<T> = public class(IList<T>) where T is Person, T has constructor; [...] Ich arbeite zwar seit mehr als 20 Jahren mit Pascal, aber diese Syntax ist mir neu und latuernich moechte ich wissen, was das ist und wie man es verwenden kann. Falls jemand einen Link zu einem Tutorial hat, waere ich dankbar. |
Re: Container-Klassen in Delphi
Das ist ja auch kein Pascal, sondern C#.
|
Re: Container-Klassen in Delphi
Nope, das ist Roberts Chrome-Schnipsel :zwinker: .
@mashutu: ![]() Kurz umrissen kannst du beim Benutzen der Klasse den Typparameter T durch einen beliebigen Typ ersetzen (wobei da noch die Constraints eine Rolle spielen, die du mitgequotet hast: T muss von Person abgeleitet sein und einen öffentlichen, parameterlosen Konstruktor haben).
Delphi-Quellcode:
var
list : PersonList<Customer>; // T = Customer (eine von Person abgeleitete Klasse) begin [...] list[0].Orders[...]; // Person besitzt keine Eigenschaft Orders, dennoch müssen wir nicht casten, da Item[] ja nicht Person sondern T zurückgibt. Und in unserem Fall ist T = Customer end; |
Re: Container-Klassen in Delphi
Danke an Lucky und Khabarakh fuer die kurze Info und den Link zu Chrome
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 01:48 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 by Thomas Breitkreuz