Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Algorithmen, Datenstrukturen und Klassendesign (https://www.delphipraxis.net/78-algorithmen-datenstrukturen-und-klassendesign/)
-   -   [Erledigt] Interface aus DLL per LateBinding - FreeLibrary tödlich? (https://www.delphipraxis.net/189047-%5Berledigt%5D-interface-aus-dll-per-latebinding-freelibrary-toedlich.html)

DeddyH 28. Apr 2016 13:16


[Erledigt] Interface aus DLL per LateBinding - FreeLibrary tödlich?
 
Ich bastele (mehr zum Spaß) gerade an einem Plugin-System. Kern des Ganzen ist ein Interface, das aus einer DLL geladen wird (Objekte gehen ja nicht, Interfaces schon). Dazu durchlaufe ich ein angegebenes Verzeichnis, suche dort nach DLLs und lade diese dann dynamisch. Klappt auch alles soweit, nur will ich als ordentlicher Mensch auch je LoadLibrary ein FreeLibrary aufrufen. Dann fliegt mir aber alles um die Ohren, daher meine Frage zum FreeLibrary in der geschilderten Konstellation:
[ ] Darf ich nicht verwenden
[ ] Kann ich nicht verwenden, es gibt etwas anderes
[ ] Muss ich nicht verwenden

(Zutreffendes bitte ankreuzen :mrgreen:)

P.S.: MemoryLeaks bekomme ich keine angezeigt, aber das muss ja nichts heißen.

P.P.S.: Vielleicht etwas Code, damit man sich das besser vorstellen kann
Delphi-Quellcode:
// Minimalistisches Interface
IPlugin = interface
  ['{818EFBE5-DA89-440B-88C5-7F3D964EA002}']
  procedure Work; stdcall;
end;

// Exportierte DLL-Funktion
function LoadPlugin: IPlugin; stdcall; export;

// Dynamisches Laden (Auszug)
lHandle := LoadLibrary(PChar(Path + Rec.Name));
if lHandle <> 0 then
  begin
    LoadPlugin := GetProcAddress(lHandle, FUNCNAME);
    if Assigned(LoadPlugin) then
      begin
        Plugin := LoadPlugin;
        if Assigned(Plugin) then
          Plugin.Work;
      end;
  end;

Neutral General 28. Apr 2016 13:25

AW: Interface aus DLL per LateBinding - FreeLibrary tödlich?
 
Darfst du nicht verwenden. Ist aber doch logisch. Der Code hinter dem Interface liegt in der DLL. Wenn du mit FreeLibrary die DLL aus dem Speicher entfernst ist der Code weg auf den dein Interface verweist.

Bzw. du darfst FreeLibrary halt erst aufrufen wenn du dein Plugin und alle Interfaces daraus nicht mehr verwenden willst.

DeddyH 28. Apr 2016 13:27

AW: Interface aus DLL per LateBinding - FreeLibrary tödlich?
 
Da habe ich mich wohl blöd ausgedrückt. Das FreeLibrary sollte natürlich erst bei Programmende aufgerufen werden, nachdem alle Interfaces genilt sind.

[edit] Hat sich erledigt, ich habe das Ganze etwas umgebaut, jetzt kann ich auch FreeLibrary aufrufen. Irgendwo hatte ich wohl einen logischen Fehler drin, so dass die Interfaces noch nicht freigegeben waren. [/edit]

Sir Rufo 28. Apr 2016 14:32

AW: Interface aus DLL per LateBinding - FreeLibrary tödlich?
 
Wenn die Anwendung sich beendet, dann werden auch alle DLLs dieser Anwendung automatisch aus dem Speicher entfernt. Egal ob du da ein FreeLibrary machst oder nicht. Also kannst du es auch gleich sein lassen.

DeddyH 28. Apr 2016 14:36

AW: [Erledigt] Interface aus DLL per LateBinding - FreeLibrary tödlich?
 
Ich habe jetzt noch einmal ganz genau nachgelesen und habe das entscheidende Sätzchen gefunden:
Zitat:

The system unloads a module when its reference count reaches zero or when the process terminates (regardless of the reference count).
Also spar ich mir das.


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