Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Sonstige Fragen zu Delphi (https://www.delphipraxis.net/19-sonstige-fragen-zu-delphi/)
-   -   Delphi Units / Forms in DLLs auslagern (https://www.delphipraxis.net/113987-units-forms-dlls-auslagern.html)

moelski 17. Mai 2008 20:58


Units / Forms in DLLs auslagern
 
Moin !

Wir haben in unserer Anwendung einen ganz Schwung an Units die wir gerne in DLLs auslagern würden um die Größe der EXE Datei zu reduzieren und um den Speicherverbrauch nach dem Start zu reduzieren.

Nun stellen sich uns da aber ein paar Fragen ...
1) Was muss man beachten wenn man eine normale Unit in eine DLL "umwandeln" will. Vor allem wenn ich bedenke das die Units teilweise auf die Anwendung zugreifen um z.B. bestimmte Eigenschaftswerte zu lesen / schreiben.
Also würde z.B. sowas funktionieren aus einer DLL:
Delphi-Quellcode:
Form1.Label.text := 'Hallo Welt'
Oder würde sowas zu Problemen führen ?
2) Die Units werden ja (so hoffe ich mal) dann nachgeladen wenn die beinhalteten Funktionen / Proceduren benötigt werden. Wenn die DLL aber danach nicht mehr weiter benötigt wird, wird sie dann auch wieder aus dem Speicher entfernt? Also gibt es eine Art "Free" für die DLLs, oder macht das Windows im Hintergrund dynamisch selber?
3) Wir haben einige Units die eine weitere Unit mit Formular verwenden. Also in der normalen Unit steht der Code um Daten umzurechnen und die Formulare dienen dann für Einstellungen die man dazu tätigen kann. Das müsste man ja dann in 2 DLLs auslagern. Stellt es dann ein Problem da wenn man von der ersten Unit (Berechnung) auf die zweite Unit mit dem Formular zugreifen muss um dort bestimmte Settings für die Berechnung abzuchecken?
Oder kann man mit den DLLs letztlich genauso arbeiten als hätte man eine "normale" Unit (bzw. Unit mit Formular) im Projekt eingebunden?
4) Kann man in eine DLL überhaupt ein Formular packen ?!
5) Ergeben sich andere Nachteile durch die Verwendung von DLLs oder gibt es da besondere Stolpersteine wo man aufpassen sollte?

Und noch als Nachtrag ... Gibt es mitunter bessere Lösungen als DLLs?

mkinzler 17. Mai 2008 21:09

Re: Units / Forms in DLLs auslagern
 
2) FreeLibrary()
1+3) Du kannst nicht direkt auf Objekte innerhalb der Dll (z.B. eine Form) zugreifen, sondern musst Schnittstellen-Funktionen schreiben
4) Ja, der Zugriff kann dann aber nur aus dieser heraus erfolgen. Achtung es wird dann auch ein eigener VCL-Kontext verwendet
Alternative: Bpl, ActiveX/COM-Dll

Bernhard Geyer 17. Mai 2008 21:10

Re: Units / Forms in DLLs auslagern
 
Wie wäre es wenn du nur beim Programmstart benötigte Formular gleich erzeugst (Am besten wäre es nur das Hauptformular erzeugen zu lassen).
Ansonsten wirst du entweder viel Aufwand (Aufbau passender BPL-Packages mit dynamischen Laden/Entladen) treiben müssen. "Normale" DLL's sind hier eh unpassend da du damit im Endeffekt mehr Speicherverbrauch provizierst als mit einer einzelnen Exe.

moelski 17. Mai 2008 21:15

Re: Units / Forms in DLLs auslagern
 
Moin !

Ich lese gerade hier:
http://delphi.about.com/od/objectpas...bpl_vs_dll.htm

Wäre das ein besserer Weg für uns wenn wir Packages verwenden?
Die DLLs müssen wir eh nicht anderen zur Verfügung stellen sondern sind nur für unsere Anwendung gedacht.

mkinzler 17. Mai 2008 21:18

Re: Units / Forms in DLLs auslagern
 
Zitat:

Wäre das ein besserer Weg für uns wenn wir Packages verwenden?
Ja, aber dann muss die Exe komplett gegen Bpls gelinkt werden ( auch RTL + VCL)

moelski 17. Mai 2008 21:20

Re: Units / Forms in DLLs auslagern
 
Moin !

Zitat:

Ja, aber dann muss die Exe komplett gegen Bpls gelinkt werden
Und das bedeutet genau was?
Sorrry wenn ich da etwas unbeholfen nachfrage, aber das Thema ist recht neu für mich. :roteyes:

RWarnecke 17. Mai 2008 21:24

Re: Units / Forms in DLLs auslagern
 
Es müssen verschiedene BPL-Packages von Delphi mitverteilt werden zu der Anwendung.

moelski 17. Mai 2008 21:28

Re: Units / Forms in DLLs auslagern
 
Moin !

Aber wenn ich das hier richtig verstehe:
http://delphi.about.com/od/objectpas.../aa012301a.htm

Dann könnte man doch einzelne Teile der Anwendung in Packages auslagern und diese vor der Benutzung nachladen und anschließend wieder freigeben, oder?

Oder kann ich bei Packages nur sagen "ganz oder gar nicht"? Will heizen muss ich die ganze Anwendung in Packages zerlegen lassen und eben nicht nur selektierte Teile?

mkinzler 17. Mai 2008 21:29

Re: Units / Forms in DLLs auslagern
 
Es geht leider nicht nur teilweise Bpls zu verwenden, aber du kannst entscheiden, welche automatisch geladen werden und welche du dynamisch nachlädst

Apollonius 17. Mai 2008 21:31

Re: Units / Forms in DLLs auslagern
 
Der springende Punkt ist: Alle Units, die in mehreren Modulen genutzt werden, müssen in einem Package liegen. Das gilt insbesondere für die Units System und SysInit sowie die VCL-Units. Diese sind in den Packages RTL und VCL. Diese beiden Packages musst du folglich zusätzlich zu den eigenen Packages mit deiner Anwendung mitliefern.


Alle Zeitangaben in WEZ +1. Es ist jetzt 14:38 Uhr.
Seite 1 von 2  1 2      

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