AGB  ·  Datenschutz  ·  Impressum  







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

Units / Forms in DLLs auslagern

Ein Thema von moelski · begonnen am 17. Mai 2008 · letzter Beitrag vom 17. Mai 2008
Antwort Antwort
Seite 1 von 2  1 2      
moelski

Registriert seit: 31. Jul 2004
1.110 Beiträge
 
Delphi 2010 Professional
 
#1

Units / Forms in DLLs auslagern

  Alt 17. Mai 2008, 21:58
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:
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?
Dominik Schmidt
Greetz Dominik

I love Delphi 2007/2010
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.862 Beiträge
 
Delphi 11 Alexandria
 
#2

Re: Units / Forms in DLLs auslagern

  Alt 17. Mai 2008, 22:09
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
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer
Online

Registriert seit: 13. Aug 2002
17.203 Beiträge
 
Delphi 10.4 Sydney
 
#3

Re: Units / Forms in DLLs auslagern

  Alt 17. Mai 2008, 22:10
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.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
moelski

Registriert seit: 31. Jul 2004
1.110 Beiträge
 
Delphi 2010 Professional
 
#4

Re: Units / Forms in DLLs auslagern

  Alt 17. Mai 2008, 22:15
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.
Dominik Schmidt
Greetz Dominik

I love Delphi 2007/2010
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.862 Beiträge
 
Delphi 11 Alexandria
 
#5

Re: Units / Forms in DLLs auslagern

  Alt 17. Mai 2008, 22:18
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)
Markus Kinzler
  Mit Zitat antworten Zitat
moelski

Registriert seit: 31. Jul 2004
1.110 Beiträge
 
Delphi 2010 Professional
 
#6

Re: Units / Forms in DLLs auslagern

  Alt 17. Mai 2008, 22:20
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.
Dominik Schmidt
Greetz Dominik

I love Delphi 2007/2010
  Mit Zitat antworten Zitat
Benutzerbild von RWarnecke
RWarnecke

Registriert seit: 31. Dez 2004
Ort: Stuttgart
4.408 Beiträge
 
Delphi XE8 Enterprise
 
#7

Re: Units / Forms in DLLs auslagern

  Alt 17. Mai 2008, 22:24
Es müssen verschiedene BPL-Packages von Delphi mitverteilt werden zu der Anwendung.
Rolf Warnecke
App4Mission
  Mit Zitat antworten Zitat
moelski

Registriert seit: 31. Jul 2004
1.110 Beiträge
 
Delphi 2010 Professional
 
#8

Re: Units / Forms in DLLs auslagern

  Alt 17. Mai 2008, 22:28
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?
Dominik Schmidt
Greetz Dominik

I love Delphi 2007/2010
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.862 Beiträge
 
Delphi 11 Alexandria
 
#9

Re: Units / Forms in DLLs auslagern

  Alt 17. Mai 2008, 22:29
Es geht leider nicht nur teilweise Bpls zu verwenden, aber du kannst entscheiden, welche automatisch geladen werden und welche du dynamisch nachlädst
Markus Kinzler
  Mit Zitat antworten Zitat
Apollonius

Registriert seit: 16. Apr 2007
2.325 Beiträge
 
Turbo Delphi für Win32
 
#10

Re: Units / Forms in DLLs auslagern

  Alt 17. Mai 2008, 22:31
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.
Wer erweist der Welt einen Dienst und findet ein gutes Synonym für "Pointer"?
"An interface pointer is a pointer to a pointer. This pointer points to an array of pointers, each of which points to an interface function."
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 08:32 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