AGB  ·  Datenschutz  ·  Impressum  







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

Rückgabe von Interfaces an C++ DLL

Offene Frage von "karlkoch"
Ein Thema von karlkoch · begonnen am 4. Jun 2009 · letzter Beitrag vom 4. Jun 2009
Antwort Antwort
karlkoch

Registriert seit: 26. Feb 2006
Ort: Leipzig
30 Beiträge
 
Delphi 10.4 Sydney
 
#1

Rückgabe von Interfaces an C++ DLL

  Alt 4. Jun 2009, 13:26
Hallo,

folgendes Problem.

Ich habe in Delphi Interfaces und Klassen deklariert, die die Interfaces entsprechend implementieren. Zusätzlich habe ich eine DLL in C++ geschrieben, die mit diesen Interfaces arbeitet. Ansich funktioniert das auch. Probleme gibt es jedoch, wenn ich ein Interface zurückgeben will, also z.B.

Delphi-Quellcode:
function GetObject: IFoo; stdcall;
begin
  Result := TFoo.Create;
end;
Das führt immer zu einer Access Violation. Ich habe bemerkt, dass bei einem Aufruf von GetObject unter Delphi "Result" einen Anfangswert von "nil" besitzt. Wird die Funktion aus der C++ DLL heraus aufgerufen, dann besitzt "Result" einen zufälligen Wertn, was bei einer Zuweisung an Result dann natürlich zu der Access Violation führt.

Meine Frage daher:
Gibt es hier noch ein generelles Problem zwischen C++ und Delphi? Lassen sich Interfaces womöglich gar nicht so an C++ DLLs zurückgeben, weil das "Result" Verhalten unterschiedlich implementiert ist? Andere Codes lösen solche Rückgaben immer über out-Parameter. Das funktioniert bei mir dann auch, jedoch finde ich das unschöner.

Kann mir jemand dafür eine Erklärung geben?

karlkoch
  Mit Zitat antworten Zitat
Benutzerbild von sirius
sirius

Registriert seit: 3. Jan 2007
Ort: Dresden
3.443 Beiträge
 
Delphi 7 Enterprise
 
#2

Re: Rückgabe von Interfaces an C++ DLL

  Alt 4. Jun 2009, 13:36
Ein Interface (als Result) wird immer als letzter Call by Reference Wert übergeben. also egal ob du:
function getFoo:IFoo; oder
procedure getFoo(out Value:IFoo); schreibst. Es wird immer das zweite (die Procedure) daraus gemacht. Nur die Procedure sagt dem Delphi Compiler, dass hier ein uninitialisierter Parameter kommt. Das wird leider bei der Funktionslösung übersehen.
Dieser Beitrag ist für Jugendliche unter 18 Jahren nicht geeignet.
  Mit Zitat antworten Zitat
karlkoch

Registriert seit: 26. Feb 2006
Ort: Leipzig
30 Beiträge
 
Delphi 10.4 Sydney
 
#3

Re: Rückgabe von Interfaces an C++ DLL

  Alt 4. Jun 2009, 15:25
Hallo sirius,

heißt dass es gibt hier keine Lösung weil Delphi einen Bug hat, oder woher kommt diese Einschränkung?
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu
Online

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

Re: Rückgabe von Interfaces an C++ DLL

  Alt 4. Jun 2009, 15:34
Du könntest notfalls die Referenzzählung umgehen und Result selber initialisieren
Delphi-Quellcode:
function GetObject: IFoo; stdcall;
begin
  Integer(Result) := 0;
  Result := TFoo.Create;
end;
[add]
Mal zur Info, da ich selber grad einige Interfaces zusammenbastel...

Wie ist das in Delphi, ist da beim Prozerurstart die Referenz auch mal nil?
Nicht daß der Code dann in Delphi Probleme macht und Referenzen von vorher in der Resultvariale enthaltenen Interfaces nicht freigegeben werden.
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
karlkoch

Registriert seit: 26. Feb 2006
Ort: Leipzig
30 Beiträge
 
Delphi 10.4 Sydney
 
#5

Re: Rückgabe von Interfaces an C++ DLL

  Alt 4. Jun 2009, 16:27
Zitat von himitsu:
Du könntest notfalls die Referenzzählung umgehen und Result selber initialisieren
Delphi-Quellcode:
function GetObject: IFoo; stdcall;
begin
  Integer(Result) := 0;
  Result := TFoo.Create;
end;
Interessanterweiße habe ich das auch mal gemacht, allerdings kommt dann bei C++ im Debugger die Fehlermeldung, dass das Register ebp ungültig ist.
  Mit Zitat antworten Zitat
Benutzerbild von sirius
sirius

Registriert seit: 3. Jan 2007
Ort: Dresden
3.443 Beiträge
 
Delphi 7 Enterprise
 
#6

Re: Rückgabe von Interfaces an C++ DLL

  Alt 4. Jun 2009, 17:45
Zitat von karlkoch:
Hallo sirius,

heißt dass es gibt hier keine Lösung weil Delphi einen Bug hat, oder woher kommt diese Einschränkung?
Nein Delphi hat hier IMHO keinen Bug. Hier fehlt es (anscheinend) an einer klaren Definition. So wie "stdcall" die allgemeine Übergabekonvention ist fehlt es im Deteil, wie mit Interfaces zu verfahren ist. Wie gesagt, aus der Funktion wird eben die Procedure (Delphi nimmt allerdings anstatt out --> var), soweit ist die Konvention noch eindeutig. Aber wer muss nun das Funktionsresult initialisieren. C sagt, dass die Funktion dies zu tun hat und Delphi hätte gern den Aufrufer dazu verpflichtet. Daran hakt es.

Vielleicht liegt sogar tatsächlich einer von beiden falsch, müsste man mal bei M$ nachsehen, wie die nun genau stdcall definieren. (Ich hab da ehrlich gesagt, noch nie etwas zu gelesen)
Dieser Beitrag ist für Jugendliche unter 18 Jahren nicht geeignet.
  Mit Zitat antworten Zitat
Benutzerbild von sirius
sirius

Registriert seit: 3. Jan 2007
Ort: Dresden
3.443 Beiträge
 
Delphi 7 Enterprise
 
#7

Re: Rückgabe von Interfaces an C++ DLL

  Alt 4. Jun 2009, 17:46
Zitat von himitsu:
Wie ist das in Delphi, ist da beim Prozerurstart die Referenz auch mal nil?
Hä? Was meinen?
Dieser Beitrag ist für Jugendliche unter 18 Jahren nicht geeignet.
  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 20:08 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