Hypercell ein ] Hypercell aus ] Zeige Navigation ] Verstecke Navigation ]
c++.de  
   

Die mobilen Seiten von c++.de:
http://m.c-plusplus.de
Infos hier [BETA]

  
c++.de :: VCL (C++ Builder) ::  Dll Projekt mit MEMMGR.LIB - BORLNDMM.dll wird nicht benötigt     Zeige alle Beiträge auf einer Seite Auf Beitrag antworten
Autor Nachricht
Gast321
Unregistrierter




Beitrag Gast321 Unregistrierter 09:13:07 03.08.2012   Titel:   Dll Projekt mit MEMMGR.LIB - BORLNDMM.dll wird nicht benötigt            Zitieren

Hallo,

ich habe eine Frage. Und zwar habe ich ein dll Projekt, erstellt mit C++ Builder XE. Folgende Konfiguration:

C++ Builder XE
"Mit dynamischer RTL linken" - false
"Laufzeit-Packages verwenden" - false

Aufgrund des bekannten Hinweises "...müssen Sie die Bibliothek MEMMGR.LIB dem DLL-Projekt ..." habe ich "MEMMGR.LIB" zu dem Projekt hinzugefügt (über Projekt->Dem Projekt hinzufügen).

Die Exe die die dll verwendet (ebenfalls erstellt mit C++ Builder XE, Konfiguration ist die gleiche (also keine dyn. RTL, keine Laufzeit-Packages, MEMMGR.LIB ebenfalls hinzugefügt).

Allerdings scheint MEMMGR.LIB nicht wirklich verwendet zu werden, weil:
- die exe läuft, auch wenn "BORLNDMM.dll" nicht im selben Verzeichnis liegt. Auch wenn BORLNDMM.dll im selben Verzeichnis liegt, wird diese nicht verwendet (ich kann sie während der Laufzeit der exe löschen)
- die erzeugte dll ist binär bis auf wenige Bytes identisch, egal ob mit oder ohne MEMMGR.LIB


Was mache ich falsch? Ich hätte erwartet dass die exe überhaupt nicht startet, wenn die BORLNDMM.dll nicht verfügbar ist?! Muss ich sonst noch irgendwo in den Projekteinstellungen was umsetzen um meiner dll bzw. dem Executable das die dll verwendet zu sagen dass sie BORLNDMM.dll verwenden sollen?

Danke.
Morle
Unregistrierter




Beitrag Morle Unregistrierter 11:32:29 03.08.2012   Titel:              Zitieren

Der Hinweis ist eh irreführend, denn er bezieht sich nur auf die Speicherverwaltung. Wenn Objekte gelöscht werden, sollte man aber auch daran denken, die korrekten Destruktoren aufzurufen, was das bloße Linken der BORLNDMM.DLL nicht garantiert (da die VCL an sich trotzdem statisch bleibt und damit EXE und DLL bei Dir eine eigene Instanz erhalten!).

Generell zeugt es daher von schlechtem Stil Pointer in der EXE oder DLL zu löschen, die auf der jeweils anderen Seite erzeugt wurden und man sollte das tunlichst vermeiden. Wenn man sich aber dann doch auf den Pfad der Verdammten begeben will, dann besser gleich alles dynamisch Linken (gegen VCL und RTL).
Gast321
Unregistrierter




Beitrag Gast321 Unregistrierter 08:55:03 07.08.2012   Titel:              Zitieren

Hi,

danke für den Hinweis. Dennoch würde ich (alleine um der Neugier willen) gerne wissen, was ich noch falsch mache beim Einbinden der MEMMGR.LIB?

Hat sont noch jemand eine Idee?
c++.de :: VCL (C++ Builder) ::  Dll Projekt mit MEMMGR.LIB - BORLNDMM.dll wird nicht benötigt   Auf Beitrag antworten

Zeige alle Beiträge auf einer Seite




Nächstes Thema anzeigen
Vorheriges Thema anzeigen
Sie können Beiträge in dieses Forum schreiben.
Sie können auf Beiträge in diesem Forum antworten.
Sie können Ihre Beiträge in diesem Forum nicht bearbeiten.
Sie können Ihre Beiträge in diesem Forum nicht löschen.
Sie können an Umfragen in diesem Forum nicht mitmachen.

Powered by phpBB © 2001, 2002 phpBB Group :: FI Theme

c++.de ist Teilnehmer des Partnerprogramms von Amazon Europe S.à.r.l. und Partner des Werbeprogramms, das zur Bereitstellung eines Mediums für Websites konzipiert wurde, mittels dessen durch die Platzierung von Werbeanzeigen und Links zu amazon.de Werbekostenerstattung verdient werden kann.

Die Vervielfältigung der auf den Seiten www.c-plusplus.de, www.c-plusplus.info und www.c-plusplus.net enthaltenen Informationen ohne eine schriftliche Genehmigung des Seitenbetreibers ist untersagt (vgl. §4 Urheberrechtsgesetz). Die Nutzung und Änderung der vorgestellten Strukturen und Verfahren in privaten und kommerziellen Softwareanwendungen ist ausdrücklich erlaubt, soweit keine Rechte Dritter verletzt werden. Der Seitenbetreiber übernimmt keine Gewähr für die Funktion einzelner Beiträge oder Programmfragmente, insbesondere übernimmt er keine Haftung für eventuelle aus dem Gebrauch entstehenden Folgeschäden.