AGB  ·  Datenschutz  ·  Impressum  







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

MessageDLG - Endlos Loop in Thread

Ein Thema von alf.krause · begonnen am 22. Jun 2024 · letzter Beitrag vom 22. Jun 2024
Antwort Antwort
alf.krause

Registriert seit: 23. Apr 2007
21 Beiträge
 
Delphi 12 Athens
 
#1

MessageDLG - Endlos Loop in Thread

  Alt 22. Jun 2024, 16:49
Hallo,

ich habe seit kurzem das Problem, dass fast immer (ca. 98% Schlechtfälle) die MessageDlg's aus einem Datenmodule nicht angezeigt werden und die App Endlos "leiert" in einem Thread, wo der Debugger nicht mehr viel sagt. Der Dialog ist nicht sichtbar und es kreiselt. Debugger siehe Anhang

Delphi 12.1 Patch 1 - VcL Anwendung

1) App hat Eurekalog (7.12.5 Stable)alf, das erkennt und meldet nichts. Loop Dedection Aktiviert -ohne Erfolg, Eurekalog deaktiviert -> ohne Erfolg, Thread Überwachung aktiviert -> ohne Erfolg

2) MessageDlg über MessageBox realisiert (https://www.delphipraxis.net/175592-...-sichtbar.html) ohne Erfolg

3) die vorhandenen TopMost Fenster mal deaktiviert und geschlosssen -> ohne Erfolg

4) Application.NormalizeTopMosts vor dem MessageDlg -> ohne Erfolg

5) QUEST_PRINTAUSGLECHSRECH direkt als Text übergeben -> ohne Erfolg

Das Ganze lief schon mal bzw. sehr lange und jetzt nicht mehr. An anderer Stelle wurde aber viel geändert, so das dass SVN keine wirkliche Option ist.


Beispiel:

if MessageDlg (QUEST_PRINTAUSGLECHSRECH,mtConfirmation,[mbYes,mbNo],0) = mrYes then
....

So eine Wirkliche Idee habe ich nicht mehr.

Hat jemand einen Tipp - Danke.
Miniaturansicht angehängter Grafiken
screenshot-2024-06-22-163221.png  

Geändert von alf.krause (22. Jun 2024 um 17:18 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.062 Beiträge
 
Delphi 12 Athens
 
#2

AW: MessageDLG - Endlos Loop in Thread

  Alt 22. Jun 2024, 17:42
Also der Titel ist echt etwas verwirrend.
Nein, man nutzt die VCL niemals nie innerhalb eines "anderen" Threads, als dem Hauptthread.

Zitat:
MessageBox
Dann liegt es wohl nicht an den VCL-Dialogen.

MessageDlg nutzt standardmäßig intern die TaskDialog-API von Windows.
Unter gewissen Umständen (uraltes Windows, Idioten, VCL-Styles, sonstwas) werden intern aber VCL-Dialoge (TForm) genutzt.

Laufen bei dir Timer oder Threads, welche irgendwas machen/blockieren können?

Wie sieht die CPU-Last aus?
* hängt es nur (Sleep, WaitFor oder so)
* arbeitet irgendwas und der Thread arbeitet Volllast (Hauptthread mit 100%)

Joar, auf "Pause" im Debugger, während es im Dialog hängt
und falls man im Stack noch nichts sieht, dann versuchen mittels F7/F8 weiter zu schauen, ob man irgendwann in Code landet, welcher am Arbeiten ist/hängt.

Mal mit 32 Bit probieren?




Egal ob VCL-Dialoge oder DialogAPI vom Windows,
es läuft intern eine MessageLoop, welche alle Messages verarbeitet, also z.B. Timer und Paint der anderen Forms uvm.

Außer, dass die VCL-Dialoge TApplication.ProcessMessage nutzen und dort mehr machen,
als die "blanken" / fremden PeekMessage/TranslateMessage/DispatchMessage in der MessageLoop des Taskdialogs,
wo also WM_QUIT, OnMessage, IsPreProcessMessage, IsHintMsg, IsMDIMsg, IsKeyMsg und IsDlgMsg nicht behandelt würden, während der Dialog angezeigt wird.
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.

Geändert von himitsu (22. Jun 2024 um 17:50 Uhr)
  Mit Zitat antworten Zitat
Kas Ob.

Registriert seit: 3. Sep 2023
346 Beiträge
 
#3

AW: MessageDLG - Endlos Loop in Thread

  Alt 22. Jun 2024, 20:37
@alf.krause,
Try to manually generate a report by EurekaLog for all running threads, this might help, you can call it manually or raise an exception, with EurekaLog settings set to pause all threads when generating a report.

Your screenshot showing a thread not the main thread and most likely that is OS one not even created by your application, open Threads while debugging with IDE.
Here a screenshot showing on the right what do you see (OS threads aka externals) and on the right the main thread, in your case there might be more, either yours or OS's:
threads.jpg

Also you want to see if some API is in fact had executed and returned or not, so i suggest API monitor, there was a post explaining how to use it, and here what you might need to select
taskdialogindirect.png

Hope that helps.
Kas
  Mit Zitat antworten Zitat
alf.krause

Registriert seit: 23. Apr 2007
21 Beiträge
 
Delphi 12 Athens
 
#4

AW: MessageDLG - Endlos Loop in Thread

  Alt 22. Jun 2024, 20:52
Das mit den Themes war dann der richtig Tipp. Hier hat er sich verhaspelt. Ich habe nochmal ein (weiteres Theme) rein genommen un dann wieder raus, jetzt geht es wieder korrekt.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.062 Beiträge
 
Delphi 12 Athens
 
#5

AW: MessageDLG - Endlos Loop in Thread

  Alt 22. Jun 2024, 21:01
Das war vor Ewigkeiten schonmal ein Feature-Wunsch von mir und anderen,
dass Embarcadero endlich selbstständig den MainThread und am besten auch alle Execute der TThread-Nachfahren (System.Classes.ThreadProc) benahmt
und dass nach Jahrzehnten endlich Emba mal die neue ThreadName-API MSDN-Library durchsuchenSetThreadDescription benutzt, anstatt oder zusätzlich zu diesen beschissenen NameExceptions.

Tipp: Als erste CodeZeile in der DPR oder zumindest als erste Zeile ins OnCreate der MainForm:
TThread.NameThreadForDebugging('MainThread');
und schon siehst du im Debugger (ThreadListe) direkt, welcher es ist.
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.

Geändert von himitsu (22. Jun 2024 um 21:07 Uhr)
  Mit Zitat antworten Zitat
alf.krause

Registriert seit: 23. Apr 2007
21 Beiträge
 
Delphi 12 Athens
 
#6

AW: MessageDLG - Endlos Loop in Thread

  Alt 22. Jun 2024, 22:13
Danke an alle
  Mit Zitat antworten Zitat
Antwort Antwort


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 06:21 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