AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Delphi ExecAndWait blockt alles...incl. Threads?
Thema durchsuchen
Ansicht
Themen-Optionen

ExecAndWait blockt alles...incl. Threads?

Ein Thema von haentschman · begonnen am 10. Sep 2024 · letzter Beitrag vom 20. Sep 2024
Antwort Antwort
Benutzerbild von haentschman
haentschman

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.388 Beiträge
 
Delphi 12 Athens
 
#1

ExecAndWait blockt alles...incl. Threads?

  Alt 10. Sep 2024, 06:42
Hallöle...

Ich möchte währen der Validierung der X-Rechnung (kann bis zu 10 Sekunden dauern) dem User über eine Marquee Progressbar eine Rückmeldung geben. "Ich arbeite noch"

Gegeben:
In der X-Rechnung Unit gibt es für die Ausführung ein...
Zitat:
cmd.SaveToFile(tmpFilename+'.bat',TEncoding.ANSI);

Result := ExecAndWait(tmpFilename+'.bat',''); // int.XRechnungValidationHelperJava (214)

_CmdOutput := CmdOutput.Text;
Das die GUI nicht reagiert war logisch. Deshalb habe ich dem Progress Fenster einen Thread verpaßt, der ein ApplicationProcessMessages (Anweisung von DevExpress ) während der Zeit regelmäßig ausführt.(Bild)

Problem:
Der Thread läuft...aber nur ein mal kommt der ins "Synchronize(SyncExecute)"...solange ExecAndWait noch nicht ausgeführt wird. Das Ganze ist dann komplett blockiert! Nach dem ExecAndWait macht der Thread weiter...aber zu spät.

Frage:
1. Kann ich die function TXRechnungValidationHelperJava.Validate( in einem Task/Thread zusätzlich ausführen?
2. Warum wird das ganze blockiert?

Danke...
Miniaturansicht angehängter Grafiken
thread.png  

Geändert von haentschman (10. Sep 2024 um 06:46 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
9.582 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: ExecAndWait blockt alles...incl. Threads?

  Alt 10. Sep 2024, 08:58
Der Thread kann sich mit dem Hauptthread nicht synchronisieren, wenn dieser durch die länger dauernde Operation blockiert ist. Du solltest stattdessen die blockierende Operation in einen Thread verlagern.
Sebastian Jänicke
Alle eigenen Projekte sind eingestellt, ebenso meine Homepage, Downloadlinks usw. im Forum bleiben aktiv!
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: ExecAndWait blockt alles...incl. Threads?

  Alt 10. Sep 2024, 10:31
Jupp, es gibt nur zwei drei Wege, um sowas zu lösen:

* Die Arbeit im Hauptthread, dann kann die VCL dort halt so lange nichts machen. (nur Grafik/Wartemauszeiger zu Beginn, währenddessen halt unbewegt und zum Schluß wieder weg ... in der Hoffnung Windows reagiert nach standardmäßig 3 Sekunden nicht mit "Fenster reagiert nicht mehr")

* Die Arbeit in einem Thread, dann kann der Hauptthread in Ruhe die Wartegrafik aktualisieren
* Arbeit im Hauptthread, aber dort wird z.B. über einen Callback oder regelmäßig ProcessMessages der Wartegrafik Zeit gegeben.
* Oder Arbeit im Hauptthread und die Wartegrafik im Thread.



Wir blenden z.B. bei längeren Aktionen, bzw. nach kurzem Warten, ein Fenster (nicht VCL) ein, in einem anderen Thread erstellt und behandelt, wo per Button oder per Strg+ESC (GetAsyncKeyState) abgebrochen werden kann.
Unsere DB-Komponenten haben eine Methode, womit man sie aus einem anderen Thread heraus abbrechen kann (also wo versucht wird dem DB-Server ein Abbruchsignal zu senden, bzw. die Connection getrennt wird, wodurch die wartende Aktion im Hauptthread abbricht)

Ursprünglich auch versucht die DB-Aktion in den Thread zu verschieben und das WarteZeugs im Hauptthread, aber trotz viel Arbeit mit Blocking, ConnectionPooling uvm. hatte es immer wieder mal geknallt, da ja öfters VCL-Komponenten und Events ungeschützt an den Queries hingen.
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.

Geändert von himitsu (10. Sep 2024 um 12:23 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von haentschman
haentschman

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.388 Beiträge
 
Delphi 12 Athens
 
#4

AW: ExecAndWait blockt alles...incl. Threads?

  Alt 10. Sep 2024, 12:10
Moin...
Durch meine Erkältung bin grade gedanklich nicht so fit ...Beim Drüberlesen, und dem Gespräch mit Tbx, war es eigentlich klar. ExecAndWait läuft ja im Hauphread.
Zitat:
Du solltest stattdessen die blockierende Operation in einen Thread verlagern.
...wird auch gemacht.
  Mit Zitat antworten Zitat
rebas

Registriert seit: 18. Sep 2024
3 Beiträge
 
#5

AW: ExecAndWait blockt alles...incl. Threads?

  Alt 20. Sep 2024, 04:29
Zitat:
Hallöle...

Ich möchte währen der Validierung der X-Rechnung (kann bis zu 10 Sekunden dauern) dem User über eine Marquee Progressbar eine Rückmeldung geben. "Ich arbeite noch"
snow rider 3d
In der X-Rechnung Unit gibt es für die Ausführung ein...
Zitat:
cmd.SaveToFile(tmpFilename+'.bat',TEncoding.ANSI);

Result := ExecAndWait(tmpFilename+'.bat',''); // int.XRechnungValidationHelperJava (214)

_CmdOutput := CmdOutput.Text;
Das die GUI nicht reagiert war logisch. Deshalb habe ich dem Progress Fenster einen Thread verpaßt, der ein ApplicationProcessMessages (Anweisung von DevExpress ) während der Zeit regelmäßig ausführt.(Bild)

Problem:
Der Thread läuft...aber nur ein mal kommt der ins "Synchronize(SyncExecute)"...solange ExecAndWait noch nicht ausgeführt wird. Das Ganze ist dann komplett blockiert! Nach dem ExecAndWait macht der Thread weiter...aber zu spät.

Frage:
1. Kann ich die function TXRechnungValidationHelperJava.Validate( in einem Task/Thread zusätzlich ausführen?
2. Warum wird das ganze blockiert?

Danke...
Task oder Thread: Du kannst die TXRechnungValidationHelperJava.Validate in einem separaten Task oder Thread ausführen, um die GUI nicht zu blockieren.

Async/Wait: Verwende einen asynchronen Ansatz mit Delphi's TTask oder TThread, um das Blocking zu vermeiden und die GUI responsive zu halten.
Code:
TTask.Run(procedure
begin
  Result := ExecAndWait(tmpFilename + '.bat', '');
  TThread.Synchronize(nil, procedure
  begin
    ProgressFenster.Close;
  end);
end);
  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 23:27 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