Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi Interface Methoden Reihenfolge (https://www.delphipraxis.net/196444-interface-methoden-reihenfolge.html)

Aviator 21. Mai 2018 11:53

Delphi-Version: 10.2 Tokyo

Interface Methoden Reihenfolge
 
Hallo zusammen,

ich arbeite gerade an einem Projekt, bei dem ich eine DLL in mein Programm einbinden muss. Diese DLL wird von einem anderen Programmierer in XE4 programmiert. Mit DLLs habe ich nun schon des öfteren gearbeitet. Allerdings fast ausschließlich so, dass ich die DLL selbst programmiert (und dann auch die Interfaces selbst erstellt habe) oder ich irgendwelche Funktionen aufgerufen habe, die von der DLL direkt exportiert wurden.

Nun exportiert die besagte DLL eine Methode
Delphi-Quellcode:
function GetInstance: IMyInterface;
und gibt eine Interface Instanz zurück. Alle kein Problem ... funktioniert super. Auch das habe ich alles schon gemacht.


Nun zur eigentlichen Frage:

Das Interface sei so definiert und wird so als Instanz von der DLL zurückgegeben:

Delphi-Quellcode:
IMyInterface = interface
['{SomeGUID}']
  procedure TestProcedure1;
  function SomeValueReturningFunction: Integer;
  function AnotherFuntion: Boolean;
end;
Mir ist es jetzt passiert, dass ich eine einzelne Methode die nachträglich hinzugefügt wurde auch bei mir von Hand hinzugefügt habe. Weil ich meine Methoden aber immer alphabetisch sortiere, habe ich die Funktionen im Interface auch sortiert.

Das neue Interface beim Programmierer der DLL:

Delphi-Quellcode:
IMyInterface = interface
['{SomeGUID}']
  procedure TestProcedure1;
  function SomeValueReturningFunction: Integer;
  function AnotherFuntion: Boolean;
  function SomeAdditionalFuntion: Boolean;
end;
Das neue Interface bei mir:

Delphi-Quellcode:
IMyInterface = interface
['{SomeGUID}']
  procedure TestProcedure1;
  function AnotherFuntion: Boolean;
  function SomeAdditionalFuntion: Boolean;
  function SomeValueReturningFunction: Integer;  // <--- Diese Methode ist nach unten gewandert
end;
Ergebnis der Aktion war, dass sich die DLL relativ merkwürdig verhalten hat. Es hat zwar alles so irgendwie funktioniert, aber die zurückgegebenen Werte entsprachen nicht denen, die er wirklich zurückgegeben hatte.

Macht es also einen Unterschied in welcher Reihenfolge die Funktionen und Proceduren in einem Interface definiert sind?

mkinzler 21. Mai 2018 12:11

AW: Interface Methoden Reihenfolge
 
Jein. Beim Zugriff über Modulgrenzen (Programm <-> Dll) ist diese wichtig.

Aviator 21. Mai 2018 12:50

AW: Interface Methoden Reihenfolge
 
Zitat:

Zitat von mkinzler (Beitrag 1402616)
Jein. Beim Zugriff über Modulgrenzen (Programm <-> Dll) ist diese wichtig.

Hmm ok. Aber woran liegt das? Werden die Methoden irgendwie mit einer fixen Adresse in die Module kompiliert und dann darüber angesprochen? Oder woran liegt das genau? Kannst du das erklären?

dummzeuch 21. Mai 2018 13:04

AW: Interface Methoden Reihenfolge
 
Zitat:

Zitat von Aviator (Beitrag 1402619)
Zitat:

Zitat von mkinzler (Beitrag 1402616)
Jein. Beim Zugriff über Modulgrenzen (Programm <-> Dll) ist diese wichtig.

Hmm ok. Aber woran liegt das? Werden die Methoden irgendwie mit einer fixen Adresse in die Module kompiliert und dann darüber angesprochen? Oder woran liegt das genau? Kannst du das erklären?

Ein Interface ist eigentlich nichts anderes als ein Record mit Methodenpointern. Die Reihenfolge legt fest, welche Adresse zu welcher Methode gehört.

Mavarik 21. Mai 2018 13:52

AW: Interface Methoden Reihenfolge
 
Einfach die Interfacedefinition nicht doppelt tippen sondern immer die gleiche Datei/Unit verwenden!

Mavarik

Aviator 21. Mai 2018 15:49

AW: Interface Methoden Reihenfolge
 
Zitat:

Zitat von dummzeuch (Beitrag 1402620)
Zitat:

Zitat von Aviator (Beitrag 1402619)
Zitat:

Zitat von mkinzler (Beitrag 1402616)
Jein. Beim Zugriff über Modulgrenzen (Programm <-> Dll) ist diese wichtig.

Hmm ok. Aber woran liegt das? Werden die Methoden irgendwie mit einer fixen Adresse in die Module kompiliert und dann darüber angesprochen? Oder woran liegt das genau? Kannst du das erklären?

Ein Interface ist eigentlich nichts anderes als ein Record mit Methodenpointern. Die Reihenfolge legt fest, welche Adresse zu welcher Methode gehört.

Aha, also so wie ich es mir oben schon dachte. Danke für die Erklärung. :thumb:

Zitat:

Zitat von Mavarik (Beitrag 1402621)
Einfach die Interfacedefinition nicht doppelt tippen sondern immer die gleiche Datei/Unit verwenden!

Mavarik

Das ist schon klar. Nur so weit waren wir noch nicht, weil es noch mehr ein Test war als ein produktives Programm. Eigentlich will ich in Zukunft alles über GIT lösen. :wink:

himitsu 21. Mai 2018 20:06

AW: Interface Methoden Reihenfolge
 
DLL-Exports können über Name und/oder Index erfolgen.

Interface-Methoden werden "ausschlißelich" durchnummeriert und der Methoden-Name hat in der Interface deklatation keinerlei Wirkung.

Ich weiß im Moment nicht, ob/wie man im Pascal/Delphi den Index definieren kann, außer automatisch über die Reihenfolge der Definition.



Auch der Interface-Name hat für Windos keine Funktion, denn das kennt nur die GUID.

Folgende Deklarationen sind somit identisch:
Delphi-Quellcode:
IMyInterface = interface
  ['{C0970276-A593-4825-BA92-53FBF6CCC1F0}']
  procedure TestProcedure1;
  function SomeValueReturningFunction: Integer;
  function AnotherFuntion: Boolean;
end;

jfdsakchdsiuhdjskxgfbjhdsgaf = interface
  ['{C0970276-A593-4825-BA92-53FBF6CCC1F0}']
  procedure nfkdhkjcndbsjkrhfjkdsnbfvkds;
  function jfkdsfhajiodsjcjkdsbnjkfhbdjksa: Integer;
  function fjdshfkjdhsgfjgdsjh: Boolean;
end;

IMyIntf = interface
  ['{C0970276-A593-4825-BA92-53FBF6CCC1E1}']
  procedure TestProcedure1;
  function SomeValueReturningFunction: Integer;
end;
IMyInterface = interface(IMyIntf)
  ['{C0970276-A593-4825-BA92-53FBF6CCC1F0}']
  function AnotherFuntion: Boolean;
end;
Es kommt ausschließlich auf Reihenfolge und Funktionssignaturen drauf an.

Das geht über die Vererbung hinaus, weswegen QueryInterface/_AddRef/_Release aus IInteface überall die selben ordinalen Werte hat und alle weiteren Methoden ab da hochzählen, über alle Hierarchien hinweg.

EWeiss 21. Mai 2018 20:12

AW: Interface Methoden Reihenfolge
 
Zitat:

DLL-Exports können über Name und/oder Index erfolgen.
Exports?
Bei Interface.. ist nicht nötig wenn die API veröffentlicht wird ist das vollkommen ausreichend.

Keine meiner Interface wird exportiert.

Wenn die Reihenfolge nicht identisch ist dann wird die DLL bzw. das Interface unbrauchbar das habe ich mit dem MMX Tool festgestellt
und war mir auch vorher schon klar.

Wenn man also ein Interface Alphabetisch sortiert dann muss das für alle gelten mit gleichen Inhalt und GUID.

gruss

himitsu 21. Mai 2018 20:16

AW: Interface Methoden Reihenfolge
 
DLL-Exports war nur als Beispiel, wo es auch ordinal ist / sein kann.

Fazit ist einfach, dass Delphi die Methoden automatisch in der Reihenfolge ihrer Deklaration durchnummeriert, was impliziert, dass die Sortierung dieser Methoden immer identisch sein muß, außer man könnte in Delphi/Pascal diesen "Index" definieren.


So, wie man bei DLL-ExportsImports den Namen und den "ordinalen" Wert ebenfalls definieren kann.


Alle Zeitangaben in WEZ +1. Es ist jetzt 00:29 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