AGB  ·  Datenschutz  ·  Impressum  







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

MouseOver Sorgt für Programm Crash

Ein Thema von Delphi-Narr · begonnen am 24. Apr 2014 · letzter Beitrag vom 25. Apr 2014
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von Delphi-Narr
Delphi-Narr

Registriert seit: 29. Aug 2009
Ort: Duisburg
437 Beiträge
 
Delphi 2007 Professional
 
#1

MouseOver Sorgt für Programm Crash

  Alt 24. Apr 2014, 18:07
Hallo,
ich habe ein Programm mit GUI (zu Testzwecken), welches lediglich einen Button zum erstellen eines Objekts besitzt.
Dieses Objekt lädt im Grunde diverse DLLs und führt periodisch Updates auf allen DLLs aus (entsprechende DLL Funktion).
Das Ganze ist wie eine Art Pluginmanager zu verstehen.
Damit auch Strings zwischen den DLLs und dem Hauptprogramm ausgetauscht werden können, ist in den DLLs und den dem Hauptprogramm FastMM4 als erste Unit eingebunden.
Ist ein bestimmtes Plugin aktiv, passiert es nun, dass das Programm scheinbar ohne Grund abstürzt ("Das Programm funktioniert nicht mehr").
Dies passiert manchmal nach 3 Sekunden, manchmal nichtmal nach 3 Stunden.
Je nach MemoryManager war es auch zu beobachten, dass das Programm mit der oben genannten Fehlermeldung abstürzt, sobald man die Maus über das Programmfenster bewegt?!

Da das Programm am Wochenende zum Einsatz kommen soll, wäre es natürlich vorteilhaft, wenn es nicht andauernd abstürzen würde.

Ich lade die Programmstruktur mal als Anhang hoch. Das zum Absturz führende Tool ist "arduino_led". Verwaltet werden die "Plugins" / "Apps" vom MainController, welcher als Verbindung zu den DLLs Instanzen der Klasse "AppClass" erstellt, welche ihrerseits die DLLs laden.
Mit einem simplen Timer wird alle 10 - 20ms (je nach Wahl) die Updatefunktion ausgelöst. Bei der sichtbaren App (in diesem Beispiel nur die arduino_led) wird zusätzlich noch
getScreen aufgerufen und es werden vorher Tastenevents an die DLL geschickt. (Das Programm wird auf der Logitech G19 angezeigt).

Ich weiß leider nicht, wo mein Fehler ist, dass es immer wieder zu abstürzen kommt, da ich zur Laufzeit die DLL ja nicht debuggen kann...

Viele Grüße!
Angehängte Dateien
Dateityp: zip Tool.zip (2,03 MB, 5x aufgerufen)
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#2

AW: MouseOver Sorgt für Programm Crash

  Alt 24. Apr 2014, 18:57
Hmmm, ob du nun den FastMM einbindest oder um göttliche Unterstützung bittest ist in diesem Falle (strings) eins: nutzlos.

Nimm statt string einfach WideString und alles wird gut.
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Benutzerbild von Delphi-Narr
Delphi-Narr

Registriert seit: 29. Aug 2009
Ort: Duisburg
437 Beiträge
 
Delphi 2007 Professional
 
#3

AW: MouseOver Sorgt für Programm Crash

  Alt 24. Apr 2014, 19:18
Hm danke für den Tipp!
Ist das mit PChar nicht gewährleistet?
Habe jetzt überall in den Callback Funktionen und in der Init Funktion WideString als Variablentyp angegeben.
Mal gucken, ob es jetzt läuft

Hm anscheinend hab ich immer noch was falsch gemacht...

Geändert von Delphi-Narr (24. Apr 2014 um 19:21 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#4

AW: MouseOver Sorgt für Programm Crash

  Alt 24. Apr 2014, 19:29
Also deinen Quellcode habe ich mir nicht angeschaut, aber wenn jemand im Zusammenhang mit einer DLL von string spricht, dann kräuseln sich mir die Fußnägel

Ja, PAnsiChar oder PWideChar funktionieren (der Speichermanager ist aber eigentlich egal, denn die DLL kann auch von anderen Programmen benutzt werden und da gibt es einige, die den FastMM nicht kennen).

PChar würde ich nicht benutzen, denn dann ist der Typ abhängig vom Compiler (Unicode oder nicht).

WideString ist ein Datentyp vom Betriebssystem und funktioniert problemlos über die Programmgrenzen (also DLL) hinweg.

UPDATE
Bei den GlobalStorage-CallBack-Funktionen hast du kein stdcall; angegeben. Absicht?

Warum definierst du dafür kein Interface? Das würde einiges entzerren.
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)

Geändert von Sir Rufo (24. Apr 2014 um 19:36 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Delphi-Narr
Delphi-Narr

Registriert seit: 29. Aug 2009
Ort: Duisburg
437 Beiträge
 
Delphi 2007 Professional
 
#5

AW: MouseOver Sorgt für Programm Crash

  Alt 24. Apr 2014, 20:09
Kann ich verstehen
Das mit dem fehlenden stdcall war keine Absicht, hatte ich schlichtweg vergessen.
Habe ich jetzt hinzugefügt. Das Interface ist für eine Version 2.0 schon geplant, aber erstmal wollte ich 1.0 zum funktionieren bringen.
Muss eventuell eine Konvertierung durchgeführt werden, wenn ich Funktionen, die String als Rückgabewert haben als WideString übergeben will oder wird das automatisch gemacht?

Sehr seltsam ist, dass das Programm im Debugger quasi problemlos läuft, ohne ihn jedoch meistens sofort abschmiert. Manchmal kommt trotzdem auch im Debugger der Fehler
"Priveligierte Anweisung"
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#6

AW: MouseOver Sorgt für Programm Crash

  Alt 24. Apr 2014, 21:03
Willst du die Funktion oder den Rückgabewert übergeben?

Das sollte so funktionieren
Delphi-Quellcode:
TSomeProc = procedure( Value : WideString ); stdcall;

var
  LSomeProc : TSomeProc;
begin
  ...
  LSomeProc( DateTimeToString( now ) );
end;
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Benutzerbild von Delphi-Narr
Delphi-Narr

Registriert seit: 29. Aug 2009
Ort: Duisburg
437 Beiträge
 
Delphi 2007 Professional
 
#7

AW: MouseOver Sorgt für Programm Crash

  Alt 24. Apr 2014, 21:23
Ich möchte nur den Rückgabewert übergeben, nicht die Funktion als solches.
So wie in deinem Beispiel sieht das bei mir jetzt auch aus, nur dass es statt procedure bei mir eine function ist.
Dann muss der Fehler noch wo anders liegen. Auch eine interessante Beobachtung: Ich habe noch zusätzlich zum "Start" Button einen Button auf das Formular gepackt, welcher lediglich die Farbe des Forms auf rot ändern soll.
Wird er zuerst gedrückt (vor Start), klappt es, während der "MainController" aktiv ist, passiert da nichts, der Quelltext wird nicht erreicht (Haltepunkt).
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#8

AW: MouseOver Sorgt für Programm Crash

  Alt 24. Apr 2014, 21:44
Wegen dem "Priveligierte Anweisung"-Fehler solltest du deinen Code unbedingt nochmal bzgl. der Aufrufkonventionen prüfen und auch auf nicht initialisierte lokale Variablen.

Wirft der Compiler Warnungen oder Hinweise bei einem kompletten Rebuild?
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Benutzerbild von Delphi-Narr
Delphi-Narr

Registriert seit: 29. Aug 2009
Ort: Duisburg
437 Beiträge
 
Delphi 2007 Professional
 
#9

AW: MouseOver Sorgt für Programm Crash

  Alt 25. Apr 2014, 14:11
Das werde ich tun. Welche Aufrufkonventionen meinst du dabei?
Ein paar Warnungen spuckt er auf jeden Fall aus, die beziehen sich aber hauptsächlich auf Funktionen in anderen Units, die nicht verwendet werden.
Wenn ich gleich zu Hause bin, werde ich das genau überprüfen und dann hier aktualisieren
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#10

AW: MouseOver Sorgt für Programm Crash

  Alt 25. Apr 2014, 14:18
Das werde ich tun. Welche Aufrufkonventionen meinst du dabei?
Ein paar Warnungen spuckt er auf jeden Fall aus, die beziehen sich aber hauptsächlich auf Funktionen in anderen Units, die nicht verwendet werden.
Wenn ich gleich zu Hause bin, werde ich das genau überprüfen und dann hier aktualisieren
Diese Aufrufkonventionen meine ich

http://docwiki.embarcadero.com/RADSt...ufkonventionen

die müssen auf beiden Seiten (Anwendung, DLL) passen.
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  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 17:40 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