![]() |
Problem mit DLL / Übergabe
Hi!
Also, ich habe eine DLL geschrieben, in der unter anderem in einer Prozedur eine StringList verarbeitet wird und wieder zurückgegeben werden soll (var). Um die DLL aufzurufen, habe ich eine extra Unit, in der die DLL immer aufgerufen wird (mit mehreren Funktionen und Prozeduren). Im Hauptprogramm rufe ich dann die Schnittstelle auf, übergebe dabei einen Parameter StringList. In der schnittstelle ist dieser Parameter als "var" deklariert. Wenn die StringList dann verarbeitet wurde von der DLL und ich wieder im Hauptprogramm bin, bekomme ich aber immer eine Zugriffsverletzung. Hab es auch schon mit Strings versucht, klappt auch nicht. Vorher hatte ich einen extra Type, wobei es da auch nicht anders war mit der Zugriffsverletzung. Hab in Google geguckt und gesehen dass viele so einen Fehler hatten. Aber hab nirgends eine brauchbare Lösung gefunden. Scheint so, als wäre die zurück gegebene StringList immer leer. Liegt es am "var"? Wie muss ich das machen?? Danke schonmal... |
Re: Problem mit DLL / Übergabe
Wenn Du über den Experten das Gerüst einer DLL erstellen lässt, schreibt Delphi da einen ziemlich langen Kommentar rein. Den sollte man vielleicht auch mal lesen.
|
Re: Problem mit DLL / Übergabe
Entweder du benutzt einen anderen Speichermanager oder du versuchst es mal mit
![]() |
Re: Problem mit DLL / Übergabe
Zitat:
Zitat:
|
Re: Problem mit DLL / Übergabe
Zitat:
Möglichkeit 2: Einen fremden Speichermanager nehmen (fastmemorymanager) Edit: IStrings wäre die bessere Methode. Denn die unterstreicht den Sinn einer DLL. Dadurch wird deine DLL unabhängig von der Entwicklungsumgebung / PS in der sie programmiert wurde. Mit den Speichermanagern bindest du dich an Delphi. Genauer gesagt, du bindest dich an ein Projekt. Denn du musst ja immer denselben Speichermanager verwenden. Dieses Konzept konterkariert ein wenig den Sinn einer DLL. |
Re: Problem mit DLL / Übergabe
Wenn es nur um die Daten der StringList geht könntest du afaik auch auf die Eigenschaft Text zurückgreifen. Die liefert den Inhalt als String und denn könntest du dann als PChar in die DLL geben und verarbeiten.
|
Re: Problem mit DLL / Übergabe
Mit IStrings geht das viel einfacher/schöner:
Delphi-Quellcode:
Und will man aus dem IStrings-Interface eine eigene Klasse kopieren gibt es "SetOleStrings".
uses StdVCL, AxCtrls;
var myStrings:IStrings; myStringList:TStringList; //mystringList erstellen und füllen //transfer TStrings to IStrings GetOleStrings(myStringList,myStrings); //hier kann man jetzt myStrings.add oder mystrings.count oder mystrings.Item in der EXE und in der DLL benutzen //es wird dadurch immer die myStringList verändert. Edit: Ein konkretes Beispiel mit einer Stringliste eines Memos. Ich habe also ein Formular mit einem Button und ein Memo und folgendem Click-Event des Buttons:
Delphi-Quellcode:
Die Zeile mit dem x.Add kann ich eben auch problemlos in einer DLL machen. Das x kann ich einfach übergeben.
uses StdVCL, AxCtrls;
procedure TForm1.Button1Click(Sender: TObject); var x:IStrings; begin getolestrings(memo1.lines,x); x.Add('Text'); end; |
Re: Problem mit DLL / Übergabe
Danke für das Beispiel, ich probiers gleich aus!
|
Re: Problem mit DLL / Übergabe
Wollte grad schon den nächsten Fehler beschreiben, aber habs gerade doch noch hingekriegt. Danke! Gut zu wissen, das mit den IStrings. Einfach und sinnvoll!
|
Re: Problem mit DLL / Übergabe
Wobei mir grad auffällt, dass IStrings ja auch von Borland sind. Also anscheinend doch nicht so gut :(
Denn du brauchst anscheinend jetzt auf dem System, wo das Proramm läuft die registrierte Bibliothek stdvcl32.dll. Ist zwar auch nicht das Problem, aber dann kannst du auch die DLL für einen Speichermanager mitliefern. |
Re: Problem mit DLL / Übergabe
Blieb noch die bereits
![]() |
Re: Problem mit DLL / Übergabe
Hab ich gerade gemerkt... auf einem anderem PC läufts nicht, es kommt eine Fehlermeldung -> "Bibliothek nicht registriert" (mit den IStrings).
Dann probier ich es jetzt mal mit der anderen Möglichkeit. |
Re: Problem mit DLL / Übergabe
Auch wenn ich einen ganz normalen PChar übergeben will (was doch auch ohne extra Bibl. gehen sollte??), gibt es eine Zugriffsverletzung.
In der EXE:
Delphi-Quellcode:
uses Schnittstelle;
variable_PChar := Funktion_in_der_Schnittstelle(var1, var2); In der Schnittstelle:
Delphi-Quellcode:
In der DLL:
function Funktion_in_der_Schnittstelle(var1, var2: Double): PChar;
type TBerechnung = function (var1, var2: Double): PChar;stdcall; [...DLLladen...] [...Zeiger auf die Function in der DLL...] Result := Variable_mit_Zeiger_auf_die_Funktion(var1, var2);
Delphi-Quellcode:
Es geht, bis ich in der EXe wieder auf die variable_PChar zugreifen will, dann kommt der Zugriffsfehler. Bis dahin wurde die Variable aber nicht gefüllt. Result in der DLL hat gestimmt, wurde aber dann nicht richtig übergeben. Also ist die Variable in der EXE leer. Wie mach ich das dann, dass es richtig übergeben wird?
function Funktion_in_der_DLL(var1, var2: Double): PChar;
begin Result := '...'; end; PChar kann man doch auch so verarbeiten mit DLLs, ohne ShareMem von Borland...? |
Re: Problem mit DLL / Übergabe
Entweder machst du in DLL und Hauptprogramm "stdcall" hin oder in keinem von beiden. Gemischt geht nicht ;)
Viele Grüße P.S.: Du kannst auch "WideString" anstatt PChar verwenden... das klappt problemlos über DLLs. |
Re: Problem mit DLL / Übergabe
Ja habs oben vergessen, in der DLL steht auch stdcall.
Ok, WideString... ich probiere es... es klappt :) Mit IStrings wäre es zwar komfortabler, aber dass es auf anderen System auch funktioniert ist wohl wichtiger. |
Re: Problem mit DLL / Übergabe
Zitat:
|
Re: Problem mit DLL / Übergabe
Ja habe es jetzt mit WideStrings gemacht. Da gibt es aber keine Probleme, wenn man die DLL mit einer anderen programmiersprache aufrufen muss, oder? Also WideStrings sind Delphi-unabhänig?
|
Re: Problem mit DLL / Übergabe
Ja, Widestring ist eine Windowssache. Und die ist ziemlich nett gekapselt von Delphi. Die Funktionen dazu (die man bei Delphi nicht wissen muss) sind
![]() |
Alle Zeitangaben in WEZ +1. Es ist jetzt 13:39 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 by Thomas Breitkreuz