AGB  ·  Datenschutz  ·  Impressum  







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

Interface Methoden Reihenfolge

Ein Thema von Aviator · begonnen am 21. Mai 2018 · letzter Beitrag vom 21. Mai 2018
Antwort Antwort
Aviator

Registriert seit: 3. Jun 2010
1.611 Beiträge
 
Delphi 10.3 Rio
 
#1

Interface Methoden Reihenfolge

  Alt 21. Mai 2018, 12:53
Delphi-Version: 10.2 Tokyo
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 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?
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Interface Methoden Reihenfolge

  Alt 21. Mai 2018, 13:11
Jein. Beim Zugriff über Modulgrenzen (Programm <-> Dll) ist diese wichtig.
Markus Kinzler
  Mit Zitat antworten Zitat
Aviator

Registriert seit: 3. Jun 2010
1.611 Beiträge
 
Delphi 10.3 Rio
 
#3

AW: Interface Methoden Reihenfolge

  Alt 21. Mai 2018, 13:50
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?
  Mit Zitat antworten Zitat
Benutzerbild von dummzeuch
dummzeuch

Registriert seit: 11. Aug 2012
Ort: Essen
1.623 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#4

AW: Interface Methoden Reihenfolge

  Alt 21. Mai 2018, 14:04
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.
Thomas Mueller
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.144 Beiträge
 
Delphi 10.3 Rio
 
#5

AW: Interface Methoden Reihenfolge

  Alt 21. Mai 2018, 14:52
Einfach die Interfacedefinition nicht doppelt tippen sondern immer die gleiche Datei/Unit verwenden!

Mavarik
  Mit Zitat antworten Zitat
Aviator

Registriert seit: 3. Jun 2010
1.611 Beiträge
 
Delphi 10.3 Rio
 
#6

AW: Interface Methoden Reihenfolge

  Alt 21. Mai 2018, 16:49
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.

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.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Interface Methoden Reihenfolge

  Alt 21. Mai 2018, 21:06
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.
$2B or not $2B

Geändert von himitsu (21. Mai 2018 um 21:13 Uhr)
  Mit Zitat antworten Zitat
EWeiss
(Gast)

n/a Beiträge
 
#8

AW: Interface Methoden Reihenfolge

  Alt 21. Mai 2018, 21:12
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
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Interface Methoden Reihenfolge

  Alt 21. Mai 2018, 21:16
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.
$2B or not $2B

Geändert von himitsu (21. Mai 2018 um 21:19 Uhr)
  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:02 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