![]() |
Gleiche DLL im selben Prozess mehrfach laden?
Hallo,
in unserem Projekt hat sich jetzt die Notwendigkeit ergeben, dass gewisse Algorithmen so ausgelagert werden, dass dritte keinen Einblick in die Funktionsweisen bekommen. Also habe ich kurzerhand eine wichtige Klasse, welche vorher einfach instanziert werden konnte, wenn man die Unit eingebunden hat, in eine DLL ausgelagert, die dynamisch geladen wird. Dazu habe ich ein "Framework" zu der Klasse erstellt, welches die Funktionen nach aussen hin noch genauso anbietet wie vorher, intern jedoch lediglich die Funktionen an die DLL übergibt. Im Constructor wird die DLL per LoadLibrary geladen und im Destructor wieder freigegeben. Diese Klasse wird im Programm an verschiedenen Stellen mit unterschiedlichen Parametern und Zuständen erzeugt. Nun habe ich aber das Problem, dass die DLL ja nur einmal in den Prozess geladen wird und ein zweiter Aufruf von LoadLibrary lediglich das Handle auf diese DLL zurückliefert. Erneute Aufrufe des Constructors überschreiben dann somit die bereits bestehende Klasse in der DLL und das Programm fährt gegen die Wand. Die SuFu hat mir nur das ausgespuckt -> ![]() Die Lösung mit dem "On-the-fly-Umbenennen" kommt mir aber nicht in die Tüte. Gibt es wirklich keine Möglichkeit, die DLL einfach so wie eine Klasse unabhängig voneinander zu "instanzieren"? Wo ist das Problem dabei? Danke. Mario |
Re: Gleiche DLL im selben Prozess mehrfach laden?
Herzlich Willkommen in der DP! :hi:
Warum willst du die DLL mehrfach laden? Lade sie doch einmal (im initialization der Unit z.B.). Ich glaube da gibt es ein Verständnis-Problem bezüglich DLL's. Solche Bibliotheken arbeiten in der Regel Prozedur-orientiert und nicht mit Klassen. Das heißt ich kann die Prozeduren der DLL aufrufen wie ich gerade lustig bin, ohne an irgendwelche Objekte zu denken. Und ganz wichtig: Niemals Objekte über DLL-Grenzen hinweg benutzen. (in der Regel) |
Re: Gleiche DLL im selben Prozess mehrfach laden?
Zitat:
|
Re: Gleiche DLL im selben Prozess mehrfach laden?
Es geht nur um freie Mitarbeiter, die die Routinen zur Ansteuerung der Hardware und zur Auswertung der Daten brauchen, um die Software zu erweitern. Aber denen geht ja unsere "Rezeptur" nichts an. Daher bekommen sie die DLL und das Interface, womit sie arbeiten können. Sonst bräuchten sie die Units, womit sie auch gleich den Code für die Algorithmen hätten.
Zitat:
|
Re: Gleiche DLL im selben Prozess mehrfach laden?
Zum kompilieren brauchen sie doch nur die kompilierten Units (*.dcu). Somit hätten sie auch keine Einsicht in den Quellcode.
|
Re: Gleiche DLL im selben Prozess mehrfach laden?
Aber nicht, wenn wir mit D6 und der eine zB mit D7 arbeitet, leider ... ;)
|
Re: Gleiche DLL im selben Prozess mehrfach laden?
Zitat:
//Offtopic: Zitat:
|
Re: Gleiche DLL im selben Prozess mehrfach laden?
Ja, aber das wäre ja gerade Sinn der Sache in dem Fall! :mrgreen:
Naja, mal schauen, ob und wie ich die Callbacks "On Demand" übergeben kann. Sonst muss ich mir was anderes einfallen lassen. Zitat:
Was hätte ich denn sonst noch für Möglichkeiten? In C++ könnte man ja die *.obj weitergeben, aber damit sind wir hier ja nicht unterwegs. |
Re: Gleiche DLL im selben Prozess mehrfach laden?
Zitat:
DIE Alternative zu DLL's sind BPL's. Das sind zwar auch nur DLL's aber da kümmert sich Delphi drum, das man die Objekte keuz und quer benutzen kann. |
Re: Gleiche DLL im selben Prozess mehrfach laden?
Aber ist da das Konzept nicht das gleiche? Wenn ich mit LoadLibrary statt einer DLL eine BPL lade ...?
|
Re: Gleiche DLL im selben Prozess mehrfach laden?
Dann wäre es das selbe.
Aber wenn du deiner Anwendung sagst (Projekt-Optionen): "Benutze Runtime-Packages und LoadPackage(MyFunctions.bpl)" dann kannst du ganz normal auf die Klassen, die aus der BPL stammen, zugreifen. Ganz so als hättest du sie per Unit geused (was für ein Wort). Dafür musst du aber nur die BPL und die DCP weitergeben und nicht den Sourcecode. |
Re: Gleiche DLL im selben Prozess mehrfach laden?
Und das funktioniert über Delphi-Grenzen hinweg? Also wenn ich das mit D6 erstelle, kann das einer mit D7 einbinden und compilen, ohne dass er die Sources braucht?
|
Re: Gleiche DLL im selben Prozess mehrfach laden?
Nein, ich glaube auch BPLs sind Versions abhängig.
|
Re: Gleiche DLL im selben Prozess mehrfach laden?
Hmmm ... wenn Luckie sagt "ich glaube" dann gibt es scheinbar kein geschriebenes Gesetz, was die Sache eindeutig regelt. :)
Insofern müsste man es mal ausprobieren. //edit: Ich denke, so lange die Abhängigkeiten erfüllt werden, sollte es nicht von der Version abhängen. Weil: Der Zugriff auf die Objekte und Klassen in der DLL erfolgt ja über Strings. Also ist der Teil schon mal versionsunabhängig. Wenn meine BPL eine andere BPL required, muss ich natürlich dafür sorgen, das die passende da ist. Man kann z.B. nicht einfach die vcl.bpl von D6 mit der von D7 tauschen. Dann knallts natürlich. Insofern sollte die Version in diesem Fall hier, keine Rolle spielen. |
Re: Gleiche DLL im selben Prozess mehrfach laden?
Ich glaub auch, dass sie Versionsabhängig sind. Wenigstens die VCL60 wird er gegen die VCL70 tauschen wollen, dann will er nochmal neu compilen und dann ists das gleiche Problem wie vorher. ;)
Mir ist aber grad eine schmutzige Idee gekommen ... :stupid: |
Re: Gleiche DLL im selben Prozess mehrfach laden?
Ich beziehe in diesem Fallmein Wissen nicht aus eigener Erfahrung, sondern weil ich meine dies mal hier im Forum von anderen Mitglieder so gehört zu haben. Und man muss es nicht unbedingt ausprobieren, es reicht die Dokumentation dazu zu konsultieren. Ein Hinweis liefert auch die Tatsache, dass die Namensgebung von den Delphi ID eigenen BPLs immer die Compiler Version beinhalten.
Zitat:
![]() Zitat:
|
Re: Gleiche DLL im selben Prozess mehrfach laden?
Ja, das hab ich auch grad gelesen, aber das bezieht sich ja zu 95% auf die Packages für Delphi. Die sind durch die Abhängigkeiten zur VCL,... natürlich versionsabhängig.
Aber so ein kleines, feines Package mit einer selbstgeschrieben Klasse drin, sollte in den meisten Delphis funktionieren. (Behaupte ich, ohne es ausprobiert zu haben) |
Re: Gleiche DLL im selben Prozess mehrfach laden?
Nun ja, wenn der Delphi Compiler intern was anderes macht, als zum Beispiel der Vorgänger mit dem die BPL erstellt wurde, dann passt das schon nicht mehr zusammen.
|
Re: Gleiche DLL im selben Prozess mehrfach laden?
Das stimmt.
Aber was soll er denn anders machen? Die Schnittstelle zur BPL sind ja die exportierten Funktionen. Diese haben einen Namen gemäß er Delphi-Nomenklatur (diese Dinger mit Funktion@Klasse@Unit). Solange diese Nomenklatur gleich bleibt, sollte es klappen. Aber so, werden wir das wahrscheinlich nicht klären. Entweder finden wir einen Compiler-Freak der uns eine eindeutige Antwort gibt, oder wir müssen es ausprobieren. :) |
Re: Gleiche DLL im selben Prozess mehrfach laden?
Ich probier erstmal meinen Schweinekram hier, wenn das nicht klappt, dann das mit der BPL ... ;)
Aber erstmal Pause ... Seh schonwieder den Wald vor lauter Bäumen nicht mehr. :mrgreen: |
Re: Gleiche DLL im selben Prozess mehrfach laden?
Wäre es da nicht evtl. einfacher die DLL so zu strukturieren, dass der gleichzeitige Zugriff aus einer Anwendung funktioniert? Also keine globalen Variablen innerhalb der DLL verwenden und damit ist meistens schon ein Großteil getan.
Typischerweise kann man so etwas dann so lösen, dass die Objekte als Parameter übergeben werden. Entweder per ID oder sogar direkt den Pointer. Ich kenne jetzt die Schnittstelle nicht weswegen ich da kein wirklich sinnvolles Beispiel nennen kann. Aber ich denke an nachfolgendem Pseudo-Code dürfte das Prinzip klar werden.
Code:
Vorteil davon wäre, falls sich was an den Klassen verändert bleiben sie kompatibel, da ja alles innerhalb der DLL abgewickelt wird. Evtl kann man dem Kompfort zu liebe dann auch noch eine Wrapperklasse erstellen. Das ist sicher etwas mehr Aufwand aber ich denke das wäre die solideste Lösung.
net_connect(ip, port): pointer;
net_close(net: pointer); net_read(net: pointer; ...); net_write(net: pointer; ...); // Das Innere der Methoden könnte dann so aussehen. net_connect(ip, port): pointer; begin Result := TNetConnection.Create(ip, port); end; net_close(net: pointer); begin TNetConnection(net).Close; TNetConnection(net).Free; end; net_read(net: pointer; ...); begin TNetConnection(net).Read; end; |
Re: Gleiche DLL im selben Prozess mehrfach laden?
Zitat:
Alle Laufzeit BPL müssen mit der gleichen Compilerversion compiliert sein. Borland hat mit jeder Version das interne Format der BPL geändert. In der Regel muss auch noch mit der gleichen Sourceversion bei Abhängigkeiten compiliert werden. Das das nicht geklappt hat, merkt erst der Anwender. (Package kann nicht geladen werden, da mit einer anderen Version von ... compiliert wurde.) Ich habe in einem Projekt 3 Packages als Laufzeitpackages declariert. Alle nicht durchschaubaren Abhängigkeiten haben dazu geführt, das ich etwa 60 Mbyte Laufzeitumgebung mit ausliefern mußte. Gruß Peter |
Re: Gleiche DLL im selben Prozess mehrfach laden?
Zitat:
Per Pointer geht nicht, da der Benutzer ja von ausserhalb mit der Klasse arbeiten muss. Ergo muß der Compiler sie kennen und da sind wir wieder beim Problem. Ich versuche das jetzt per ID umzusetzen, indem ich in der DLL eine TObjectList habe, die die Instanzen der Klasse mitschleppt und vor jedem Zugriff auf die Funktionen, die Klasse ausserhalb durch ihre ID die richtige Instanz setzt. |
Re: Gleiche DLL im selben Prozess mehrfach laden?
Hier wäre eine ActiveX-DLL wohl eine gute Lösung.
Damit umgehst du alle bisherigen Probleme. Vorteile: * aus vielen Prog.-sprachen verwendbar; keine Probleme mit vesch. Delphi Versionen * man kann beliebig viele Objekte aus der DLL erzeugen, obwohl die DLL nur einmal geladen wurde * du bietest deinen Benutzern eine definierte Schnittstelle an; die ActiveX-DLL ist selbstdokumentierend Natürlich zu dem Preis, dass du dich erst in die Materie einarbeiten musst und manche Dinge etwas holprig von der Hand gehen. Es gibt auch Einschränkungen der Datentypen, die benützt werden können. |
Re: Gleiche DLL im selben Prozess mehrfach laden?
Hm, das klingt auch gut. Warum hat das noch keiner früher gesagt? :P Danke, werd mir das auf jeden Fall mal anschauen.
Die Lösung mit der Trennung der Instanzen in der DLL per Liste und ID funktioniert übrigens auch soweit ich das sehe. |
Re: Gleiche DLL im selben Prozess mehrfach laden?
Nachtrag zum Thema BPL's: Ja, sie sind Compiler-spezifisch. Schade. :(
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 18:23 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-2025 by Thomas Breitkreuz