Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi "Zu viele aufeinanderfolgende Exceptions..." beim DLL-Laden (https://www.delphipraxis.net/99310-zu-viele-aufeinanderfolgende-exceptions-beim-dll-laden.html)

MatthiasR 10. Sep 2007 15:02


"Zu viele aufeinanderfolgende Exceptions..." beim
 
Hallo allerseits,

ich habe folgendes Problem: wir haben in unserer Anwendung einen ganzen Haufen Formulare, die ich gerne (gruppiert nach Themengebieten) in Programmmodule auslagern würde. Da wir Formulare grundsätzlich immer über eine Steuer-Funktion ansprechen, die das Erzeugen, Anzeigen und wieder Freigeben beinhaltet, habe ich mir gedacht, ich könnte doch die Formulare in DLLs packen und jeweils die Steuerfunktionen als Schnittstelle exportieren. Gesagt getan. Nun bekomme ich aber in meiner Hauptapplikation beim Laden der DLL nach geraumer Zeit folgenden Fehler:

---------------------------
Benachrichtigung über Debugger-Problem
---------------------------
Im Projekt C:\PfadzumProjekt\Hauptapplikation.exe sind zu viele aufeinander folgende Exceptions aufgetreten: ''Zugriffsverletzung bei 0x023d456e: Lesen von Adresse 0x04634f44''. Prozess wurde angehalten. Mit Einzelne Anweisung oder Start fortsetzen.
---------------------------
OK Hilfe
---------------------------

Ich habe sowohl versucht, die DLL dynamisch über LoadLibrary zu laden, als auch statisch bei Programmstart. Beides mal bekomme ich die besagte Fehlermeldung. Im ersten Fall logischerweise erst, nachdem ich LoadLibrary aufgerufen habe. Weiß jemand, woran das liegen kann?

Über die Sinnhaftigkeit, Formulare in DLLs zu packen, lässt sich streiten. Funktionieren sollte es allemal, solange man keine Objekte über die Schnittstelle hinweg austauschen will, oder?!?

SirThornberry 10. Sep 2007 15:13

Re: "Zu viele aufeinanderfolgende Exceptions..." b
 
kannst du mal zeigen wie deine exportierten Funktionen aussehen? (also der Header)

sirius 10. Sep 2007 15:15

Re: "Zu viele aufeinanderfolgende Exceptions..." b
 
1. Deinen Aussagen entnehme ich, dass dieser Fehler auftritt noch bevor du eine Funktion aus der DLL benutzt. Ist das richtig?

(2. Kannst du die prinzipielle Struktur der DLL und des Aufrufs aus dem Hauptprogramm bitte darstellen? ) .. steht ja schon im roten Kasten

MatthiasR 10. Sep 2007 15:49

Re: "Zu viele aufeinanderfolgende Exceptions..." b
 
Zitat:

Zitat von sirius
1. Deinen Aussagen entnehme ich, dass dieser Fehler auftritt noch bevor du eine Funktion aus der DLL benutzt. Ist das richtig?

Vollkommen richtig.
Zitat:

Zitat von sirius
(2. Kannst du die prinzipielle Struktur der DLL und des Aufrufs aus dem Hauptprogramm bitte darstellen? ) .. steht ja schon im roten Kasten

Welcher rote Kasten?

Was ich grade zu meiner Schande bemerkt habe: die Schnittstellenfunktion hat doch ein Objekt als Parameter, und zwar den Sender als TControl :wall: . Also schaut meine Schnittstellenfunktion (bisher) noch so aus:
Delphi-Quellcode:
function ZeigeAn(Sender: TControl; AufrufModus: Integer): boolean;
Könnte das schon des Rätsels Lösung sein?

Wobei ich noch an einer anderen Stelle ein größeres Problem ausgemacht habe, das mir die Auslagerung der Formulare ohnehin unmöglich macht: innerhalb der auszulagernden Formulare wird das Main-Formular referenziert, ein Unding sondersgleichen, aber ist leider so. Daher kann ich die Unterformulare erstmal nicht ohne weiteres vom Rest entkapseln. Daher muss mein Vorhaben vorerst mal auf Eis gelegt werden :-/ . Trotzdem danke für die Hilfe!
:duck:

sirius 10. Sep 2007 15:58

Re: "Zu viele aufeinanderfolgende Exceptions..." b
 
Zitat:

Welcher rote Kasten?
Wenn man seinen Beitrag abschickt und zwischendurch hat jemand (hier SirT***) auch einen Beitrag geschrieben, dann kommt so ein roter Kasten mit diesem neuen Beitrag und ich darf mein gleich nochmal editieren. Soll heißen, als ich Sir's Beitrag sah, habe ich um meinen Punkt 2 eine Klammer gesetzt.

Der "Sender" als solches macht erstmal kein Problem. Aber du wirst ihn ja benutzen und dann wird es höchstwahrscheinlich zu Problemen kommen.

Das alles erklärt für mich allerdings nicht, dass Fehler noch vor dem Aufruf einer Funktion auftreten :gruebel:

Zitat:

mein Vorhaben vorerst mal auf Eis gelegt werden
Na dann :cat:

shmia 10. Sep 2007 16:26

Re: "Zu viele aufeinanderfolgende Exceptions..." b
 
Zitat:

Zitat von Infect
wir haben in unserer Anwendung einen ganzen Haufen Formulare, die ich gerne in Programmmodule auslagern würde.... könnte doch die Formulare in DLLs packen

Warum verwendest du keine Packages ?
Die DLLs können sowieso nicht von anderen Programmiersprachen genutzt werden.
Wenn du keine Packages benützt, dann zieht jede DLL einen Grossteil der VCL (~ 300 - 500 kb) nach sich.

Angenommen dein Programm benötigt als Anwendung mit allen Formularen in einer exe z.B. 10 MB.
Dann würde die Anwendung mit 5 DLLs (ausgelagerte Formulare) vielleicht 13 MB benötigen.
(und zwar nicht nur auf Platte, sondern auch im RAM)

sirius 10. Sep 2007 16:36

Re: "Zu viele aufeinanderfolgende Exceptions..." b
 
@shmia:
Abgesehen davon, dass sich das Thema für den OP eh erledigt hat und dass du mit dem NAchteil der Größe der DLLs Recht hast, aber:
Zitat:

Die DLLs können sowieso nicht von anderen Programmiersprachen genutzt werden.
Warum das? Die VCL wird ja, wie du richtig gesagt hast schön in der DLL mitgeschleppt. Von außen sollte es nur eine einfache "start" und "stop" - Funktion geben. Dadurch kann man doch auch von z.B. einer ASM-Anwendung das schöne VCL-Gerät aufrufen.
Oder habe ich jetzt etwas übersehen?


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