AGB  ·  Datenschutz  ·  Impressum  







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

Generische Interface-GUIDs

Ein Thema von Dennis07 · begonnen am 12. Sep 2022 · letzter Beitrag vom 15. Jun 2023
Antwort Antwort
Seite 1 von 3  1 23      
Dennis07

Registriert seit: 19. Sep 2011
Ort: Deutschland
488 Beiträge
 
Delphi 11 Alexandria
 
#1

Generische Interface-GUIDs

  Alt 12. Sep 2022, 13:12
Delphi-Version: 11 Alexandria
Moin Loide,
habe das jetzt schon in vielen Gruppen diskutiert und alle fanden den Vorschlag eigentlich wirklich gut und wichtig.
Was wir brauchen sind einzigartig generierte GUIDs für generische Interfaces!

Was mich wirklich jedes mal abnervt ist folgendes Szenario:
Es ist ein gewöhnlicher Tag. Draußen zwitschern die Vögel, die Sonne scheint. Man sitzt so am PC und denkt sich nichts böses. Gut gelaunt deklariere ich ein generisches Interface, und will es mit verschiedenen Typparametern in einer Funktion benutzen. Was nicht geht, zumindest nicht richtig, weil beide Interfaces die gleiche VMT und die gleiche GUID benutzen, und somit weder von einander unterscheidbar, noch die Methoden des zweiten, dritten, ... Interfaces aufrufbar.

Also, von der Wahrheit eingeholt und vor der Sinnlosigkeit des Lebens erneut resignierend, deklariere ich einzeln n Ableitungen des Interfaces mit Typenspezifikationen.

Dabei könnte es so einfach sein. Eine Syntax wie diese hier könnte uns das Leben enorm erleichtern, und die Wirtschaft durch Zeiteinsparung bei der Entwicklung weit voranbringen:
Delphi-Quellcode:
type
  IGenItf<T> = geninterface
    // Keine GUID hier, denn die wird automatisch erzeugt
    function Foo: T;
    procedure Poo;
end;
Das Keyword geninterface habe ich einfach mal an dispinterface angelehnt und frei erfunden, bietet sich aber an.

Dann könnte man einfach folgendes schreiben:
Delphi-Quellcode:
type
  TImplObject = class(TInterfacedObject, IGenItf<Integer>, IGenIntf<String>)
    // Implementierungen
    function Int_Foo: T;
    procedure Int_Poo;
    function Str_Foo: T;
    procedure Str_Poo;
    // Delegationen
    function IGenItf<Integer>.Foo = Int_Foo;
    procedure IGenItf<Integer>.Poo = Int_Poo;
    function IGenItf<String>.Foo = Str_Foo;
    procedure IGenItf<String>.Poo = Str_Poo;
end;
Das mag jetzt nicht nach viel Ersparnis an Code aussehen, bei einigen Beispielen ist das aber äußerst beträchtlich.
Was haltet ihr davon?
Dennis
  Mit Zitat antworten Zitat
TiGü

Registriert seit: 6. Apr 2011
Ort: Berlin
3.070 Beiträge
 
Delphi 10.4 Sydney
 
#2

AW: Generische Interface-GUIDs

  Alt 12. Sep 2022, 14:17
Und bei jeden Full Build kommt eine andere GUID bei raus?
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Generische Interface-GUIDs

  Alt 12. Sep 2022, 15:18
Es könnte auch sein, dass garkeine GUID generiert wird und die einfach nur 0000-000-00000-0000.... ist

Mir war so, als wenn der Compiler bei Interfaces "ohne" GUID eh gewisse Dinge verbietet / nicht kompilert, wie z.B. die Verwendung von IS und AS.
Somit wäre dabei die GUID dann eh egal, wenn sie nie verwendet würde.




Gab es bezüglich Generics bei Interfaces nicht hier mal irgendwo eine größere Diskusion/Thread?

Wenn man die GUID angibt, dann würde doch jede Ableitung die Gleiche GUID bekommen, was so auch nicht super gut wäre.
$2B or not $2B

Geändert von himitsu (12. Sep 2022 um 15:21 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
9.648 Beiträge
 
Delphi 11 Alexandria
 
#4

AW: Generische Interface-GUIDs

  Alt 12. Sep 2022, 15:21
Poste doch einfach den Link zum Featurerequest, damit auch jemand dafür voten kann. Ansonsten passiert da ohnehin nichts, egal wie viel es in Foren diskutiert wird.

Automatisch generierte GUIDs würden jedenfalls nur einen Teil der Probleme lösen. Ich hatte das Thema GUIDs bei generischen Interfaces auch schon, wenn auch mit anderem Hintergrund. Mir fällt aber schlicht keine wirklich sinnvolle Lösung dafür ein. Deshalb hatte ich dazu auch keinen Featurerequest geschrieben bzw. erst einmal danach gesucht.

Nebenbei gibt es ähnliche Themen im Hinblick auf Casts usw. ja auch bei anderen Sprachen wie C#, wo man für generische Typen kein Marshalling für interop usw. hat.
Sebastian Jänicke
AppCentral
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.475 Beiträge
 
Delphi 12 Athens
 
#5

AW: Generische Interface-GUIDs

  Alt 12. Sep 2022, 16:00
Berücksichtig man den Fakt, dass in Delphi zwei an verschiedenen Stellen deklarierte TList<string> auch formell zwei unterschiedliche Typen sind, sehe ich da noch einen sehr langen Weg bis sowas realisiert werden könnte.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.027 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#6

AW: Generische Interface-GUIDs

  Alt 12. Sep 2022, 16:06
Mach halt einfach kein supports auf nen generisches interface

Berücksichtig man den Fakt, dass in Delphi zwei an verschiedenen Stellen deklarierte TList<string> auch formell zwei unterschiedliche Typen sind
Wenn du mit "verschiedene Stellen" unterschiedliche Binaries meinst, dann ja, ansonsten nein
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Generische Interface-GUIDs

  Alt 12. Sep 2022, 16:23
Jupp, Generics werden beim Compilieren über eine Art globalen Cache verwaltet.
Wurde einmal ein generic implementiert/verwendet, und kommt an anderer Stelle nochmal "neu" vor, dann wird die bereits bestehende Deklaration verwendet.

z.B. TArray<irgendwas> in einer Unit und TArray<irgendwas> in einer anderen Unit sind somit identisch.
Im Gegensatz dazu sind "array of irgendwas" an beiden Stellen "neue" deklarationen und somit jeweils "eigene" Typen.

In einer anderen EXE/DLL natürlich nicht mehr, weil neues/anderes Compilat.
$2B or not $2B

Geändert von himitsu (12. Sep 2022 um 17:41 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.475 Beiträge
 
Delphi 12 Athens
 
#8

AW: Generische Interface-GUIDs

  Alt 12. Sep 2022, 17:34
Wenn du mit "verschiedene Stellen" unterschiedliche Binaries meinst, dann ja, ansonsten nein
Ja, da hatte ich einen Knoten im Hirn. Das kommt davon, wenn man zu viele Sachen auf einmal macht.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Dennis07

Registriert seit: 19. Sep 2011
Ort: Deutschland
488 Beiträge
 
Delphi 11 Alexandria
 
#9

AW: Generische Interface-GUIDs

  Alt 12. Sep 2022, 17:47
Berücksichtig man den Fakt, dass in Delphi zwei an verschiedenen Stellen deklarierte TList<string> auch formell zwei unterschiedliche Typen sind
Jo, aber das ist ja eine Klasse. Klassen identifizieren sich ja über die Klassenreferenz, Interfaces hingegen über ihre GUID. Wenn du zweimal das gleiche Interface mit der selben GUID hast, dann ist es auch das selbe. Das ist ja gerade der Sinn eines Interfaces, sonst bräuchte man die ja nicht (abgesehen von ARC und Mehrfachableitung natürlich).

Mach halt einfach kein supports auf nen generisches interface
Ja okay, und wie soll man das sonst machen? Außerdem löst es das Problem auch nicht, dass die Adressen in der VMT auf die selbe Stelle zeigen.

Und bei jeden Full Build kommt eine andere GUID bei raus?
Ja entweder das, oder sie werden in der DPROJ gecached, keine Ahnung. Da man auf Interfaces im Code aber eh nicht direkt über ein TGUID-Objekt, sondern in der Regel über den Interface-Namen zugreifen sollte, spielt das in 99,9% der Fälle keine Rolle. Für den Rest der Fälle muss man das dann halt konventionell lösen.

utomatisch generierte GUIDs würden jedenfalls nur einen Teil der Probleme lösen. Ich hatte das Thema GUIDs bei generischen Interfaces auch schon, wenn auch mit anderem Hintergrund. Mir fällt aber schlicht keine wirklich sinnvolle Lösung dafür ein. Deshalb hatte ich dazu auch keinen Featurerequest geschrieben bzw. erst einmal danach gesucht.
Jo, das ist richtig. Hast du einen Link?

Es könnte auch sein, dass garkeine GUID generiert wird und die einfach nur 0000-000-00000-0000.... ist

Mir war so, als wenn der Compiler bei Interfaces "ohne" GUID eh gewisse Dinge verbietet / nicht kompilert, wie z.B. die Verwendung von IS und AS.
Somit wäre dabei die GUID dann eh egal, wenn sie nie verwendet würde.
Das ist richtig, du kannst den Interfacetypen nicht direkt als Bezeichner übergeben, falls du keine GUID definiert hast. Außerdem funktioniert "as" nicht.
Genau deshalb sind GUIDs ja so wichtig.
Dennis

Geändert von Dennis07 (12. Sep 2022 um 18:10 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
9.648 Beiträge
 
Delphi 11 Alexandria
 
#10

AW: Generische Interface-GUIDs

  Alt 12. Sep 2022, 18:04
Jo, das ist richtig. Hast du einen Link?
Ich weiß nicht, ob es einen solchen Featurerequest schon gibt. Aber ich wollte darauf hinaus, dass du ansonsten einen erstellen musst, damit es eine Chance auf Umsetzung gibt.
Sebastian Jänicke
AppCentral
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23      


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:47 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