![]() |
Delphi-Version: XE5
Generics ohne Typangabe - Ist das neu?
^^^^^ XE7!!!
Da habe ich doch gerade ein wenig mit Generics herumgebastelt und bin (positiv) überrascht, dass es funktioniert:
Delphi-Quellcode:
Das war doch nicht immer so, oder doch? :gruebel:
type
TFoo = class public class procedure Bar<T>(const Value : T ); end; procedure Test; var LBar : TBar; begin TFoo.Bar( LBar ); // dieser Aufruf ist äquivalent zu TFoo.Bar<TBar>( LBar ); end; |
AW: Generics ohne Typangabe - Ist das neu?
Kann mich nicht erinnern, daß es ging,
aber ich glaub gehört zu haben, daß dieses Verhalten wurde mehrfach gewünscht wurde. [edit] XE geht und ![]() |
AW: Generics ohne Typangabe - Ist das neu?
Ohne eine kompetente Antwort geben zu können (spätestens Stevie wird das tun), meine ich dass es in trivialen Fällen (wie diesem) schon vor XE7 ging.
|
AW: Generics ohne Typangabe - Ist das neu?
Habs grad ausprobiert. Funktioniert seit Delphi 2009 ;)
Aber hatte ich auch nicht gewusst :) |
AW: Generics ohne Typangabe - Ist das neu?
getestet ... Antwort korrigiert
|
AW: Generics ohne Typangabe - Ist das neu?
Gefühlt hatte ich eigentlich auch diese Meinung im Kopf "Woanders geht es, nur bei Delphi nicht, wollen wir auch haben!".
Na gut, wir haben (hatten schon seit Ewigkeiten) es ... dann kann man ja auch was draus machen :) |
AW: Generics ohne Typangabe - Ist das neu?
Das ging nicht, glaub ich.
Delphi-Quellcode:
type
TFoo = class public class procedure Bar<T>() : T ; end; procedure Test; var LBar : TBar; begin LBar := TFoo.Bar; // dieser Aufruf ist äquivalent zu LBar := TFoo.Bar<TBar>; end; |
AW: Generics ohne Typangabe - Ist das neu?
Jo das geht tatsächlich nicht. Auch nicht in XE7.
|
AW: Generics ohne Typangabe - Ist das neu?
Das auch nicht
Delphi-Quellcode:
TFoo = class
class procedure Bar<T>( AList : TList<T> ); end; |
AW: Generics ohne Typangabe - Ist das neu?
In C# kann man die explizite Typangabe weglassen, wenn sie sich aus dem Aufrufkontext ergibt: Hier ist der Typ des Parameters bzw. des Rückgabewertes ausreichend und definiert damit den Typparameter. Offensichtlich ist das in Delphi nicht anders.
Bei C# habe ich das erst mit dem Einsatz des Refactoringtools "Resharper" bemerkt, der gnadenlos redundanten Code moniert (wenn man ihn lässt). |
AW: Generics ohne Typangabe - Ist das neu?
Zitat:
|
AW: Generics ohne Typangabe - Ist das neu?
Das Verhalten nennt sich
![]() Allerdings schmunzelt aufgrund der Eingeschränktheit des Delphi Compilers da jeder C# Entwickler nur drüber. Außerdem gibt/gab es auch Stellen, wo dann was grandios falsches rauskommt (in XE z.B. konnten Floats nicht korrekt infered werden, da kam dann Kraut und Rüben bei raus). Und auch innerhalb von generischen Klassen/Methoden kann es schonmal vorkommen, dass man eigentlich <T> weglassen könnte, der Compiler aber irgendwas moniert. Allerdings kann aufgrund der nicht vorhandenen Informationen des Compilers, dass es sich um einen konstruierten generischen Typen handelt, nur direkt auf den Typen eines Ausdrucks infered werden. Was heißt das? Dass sowas leider nicht geht:
Delphi-Quellcode:
Der Compiler weiß hier nicht mehr bei fooList, aha, das ist eine TList<T>, die passt in den Parameter list und T ist TFoo, also kannste hier bei DoIt das <TFoo> weglassen.
procedure TBar.DoIt<T>(list: TList<T>);
... var fooList: TList<TFoo>; begin bar.DoIt(fooList); // geht nicht Von Type Inference in C# bei Lambdas und generischen extension methods fang ich erstmal gar nicht an - sonst werd ich wieder depri :mrgreen: |
AW: Generics ohne Typangabe - Ist das neu?
Zitat:
|
AW: Generics ohne Typangabe - Ist das neu?
Zitat:
Immerhin weiß der Compiler ja schon vorher was für ein Typ für den Result benötigt wird. |
AW: Generics ohne Typangabe - Ist das neu?
-quatsch-
|
AW: Generics ohne Typangabe - Ist das neu?
[OT]
Zitat:
|
AW: Generics ohne Typangabe - Ist das neu?
Zitat:
![]() ![]() Zitat:
|
AW: Generics ohne Typangabe - Ist das neu?
Zitat:
|
AW: Generics ohne Typangabe - Ist das neu?
Overload kann es so grundsätzlich erstmal beim Result nicht gehen .... nicht ohne soein Inferenzzeugs, denn abgesehn von expliziten Casts könnte der Compiler sonst keine Entscheidung treffen was er nun nehmen solle.
Delphi nutzt (aktuell) halt ausschließlich die Eingabeparameter, für diese Entscheidungen, und eben nicht den Ausgabeparameter Result. Aber wenn man es genau nimmt, dann ist auch das Result ein "Parameter", welcher intern oftmals sogar als VAR-Parameter übergeben wird. |
AW: Generics ohne Typangabe - Ist das neu?
Ja, aber deswegen musst Du auch bei nicht passenden oder zu allgemeinen Parametern den Typen mit angeben. Ein Overload mit jeweils einem Objektparameter geht ja auch u.U. nach hinten los.
Delphi-Quellcode:
Procedure Foo (bar : TFooBar); overload;
Procedure Foo (bar : TBarFoo); overload; ... Foo (nil); // <<--- möööp |
Alle Zeitangaben in WEZ +1. Es ist jetzt 17:37 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