AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Thread WaitFor wird durch Application.ProcessMessages blockiert
Thema durchsuchen
Ansicht
Themen-Optionen

Thread WaitFor wird durch Application.ProcessMessages blockiert

Ein Thema von schwa226 · begonnen am 18. Feb 2011 · letzter Beitrag vom 19. Feb 2011
Antwort Antwort
schwa226

Registriert seit: 4. Apr 2008
400 Beiträge
 
#1

Thread WaitFor wird durch Application.ProcessMessages blockiert

  Alt 18. Feb 2011, 22:33
Hallo,

ich habe ein Problem wenn ich einen Thread vorzeitig beenden will.

Ich lasse den Thread in einer For Schleife einige Daten in ein TStringGrid eintragen.
Dies kann bis zu 10 Sekunden dauern. Damit die Form dabei nicht einfriert habe ich ein Application.ProcessMessages drinnen.

Möchte ich nun aber nach 5s schon abrechen indem ich Terminate und WaitFor aufrufe belibt es bei WaitFor stehen. Wenn das Update des TStringGirds fertig ist kann ich ohne Probleme den Thread beenden.

Ein Versuch auf diese Art geht nicht:
Delphi-Quellcode:
if not Terminated then
Application.ProcessMessages
Das Terminated bleibt auf False und dadurch bleibt es wieder hängen.

Application.ProcessMessages gefällt mir sowieso nicht aber wie kann man ansonsten ein "angebliches" Einfrieren der Anwendung verhindern?
Delphi 2010, Update 4 & 5
  Mit Zitat antworten Zitat
Benutzerbild von Bummi
Bummi

Registriert seit: 15. Jun 2010
Ort: Augsburg Bayern Süddeutschland
3.470 Beiträge
 
Delphi XE3 Enterprise
 
#2

AW: Thread WaitFor wird durch Application.ProcessMessages blockiert

  Alt 18. Feb 2011, 22:50
Wie lässt Du denn die Daten in das Stringgrid eintragen, hoffentlich synchronized...
Der Thread muss das Terminated beachten, wenn Du eine Schleife hast könnte das so aussehen.
Delphi-Quellcode:
i := 0;
While (i < 10) and not Terminated do
  begin
    Tuwas;
    Synchronize(MeineThreadGridBefüllmethode);
    inc(i);
  end;
Thomas Wassermann H₂♂
Das Problem steckt meistens zwischen den Ohren
DRY DRY KISS
H₂ (wenn bei meinen Snipplets nichts anderes angegeben ist Lizenz: WTFPL)
  Mit Zitat antworten Zitat
Benutzerbild von MGC
MGC

Registriert seit: 15. Mai 2008
Ort: Helsa
106 Beiträge
 
Turbo Delphi für Win32
 
#3

AW: Thread WaitFor wird durch Application.ProcessMessages blockiert

  Alt 18. Feb 2011, 23:25
Vielleicht liegt auch eine gedankliche Vermischung vor?
Wie ist denn Dein Thread gestaltet? Hast Du ein eigene Thread-Objekt abgeleitet oder nutzt Du tatsächlich wie es aussieht Application.ProcessMessages als Thread?

Leider kann man Deinem Code-Snippet keine Angaben entnehmen.
Marc
  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: Thread WaitFor wird durch Application.ProcessMessages blockiert

  Alt 18. Feb 2011, 23:53
Gib mal den gesamten Code vom Thread und vom Befüllen des StringGrids.

Die lange Zeit für das Befüllen kann auch daher kommen, dass du das StringGrid nicht mit BeginUpdate/EndUpdate auf eine Menge Daten vorbereitest.
Für dieses Befüllen würde ich mit Queue statt mit Synchronize arbeiten (warum soll der Thread warten, bis die Daten im StringGrid angekommen sind)

Warum wartest du überhaupt mit WaitFor auf den Thread?
MyThread.FreeOnTerminate := True und der entfernt sich selber aus dem Speicher.
Die ThreadVariable MyThread kannst beim Event OnTerminate auf nil setzen und gut.
Oder du führst ein eigenen Event ein OnDestroy und setzt dabei MyThread auf nil.

Application.ProcessMessages in einem Thread aufzurufen ist absolut tabu!
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 MGC
MGC

Registriert seit: 15. Mai 2008
Ort: Helsa
106 Beiträge
 
Turbo Delphi für Win32
 
#5

AW: Thread WaitFor wird durch Application.ProcessMessages blockiert

  Alt 19. Feb 2011, 00:01
Application.ProcessMessages in einem Thread aufzurufen ist absolut tabu!
Genau das meinte ich auch mit gedankliche Vermischung. Es werden für Anfänger gern mal Threads mit Application.ProcessMessages oder Application.OnIdle verglichen, um dann zur Klasse TThread überzuleiten.

Daher dachte ich, auf diese Weise könnte sich ein Fehler eingeschlichen haben. Schließlich dürfte die GUI bei Ablauf eines zusätzlichen Threads eben genau nicht einfrieren, ansonsten würde das ganze ja keinen Sinn ergeben.
Marc
  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: Thread WaitFor wird durch Application.ProcessMessages blockiert

  Alt 19. Feb 2011, 00:10
Er hat definitiv einen Thread benutzt, denn sonst macht Terminated und WaitFor keinen Sinn.

Und wenn das StringGrid ständig mit neuen Daten befeuert wird und dabei ein Neuzeichnen nach sich zieht dann ist die Anwendung ganz schön am kochen.
Wenn im Thread jetzt auch noch jedes Mal Synchronize aufgerufen wird, dann kann ich mir den Thread auch sparen.

Besser wäre es, den Thread die Daten komplett holen zu lassen und dann in einem Rutsch an das StringGrid zu übergeben.

Es könnte aber zusätzlich auch noch folgender Fehler vorliegen:
Delphi-Quellcode:
MyThread := TMyThread.Create( True );
MyThread.Execute;
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


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 20:14 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