Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi Polling im TThread (https://www.delphipraxis.net/181596-polling-im-tthread.html)

haentschman 27. Aug 2014 20:13

Delphi-Version: XE

Polling im TThread
 
Hallo alle... 8-)

Die "Anweisungen" sollen im Thread aller z.B. 10 Sekunden ausgeführt werden. Ein beherztes Sleep im Execute hat die gleiche Auswirkung. Nur wenn der Thread von Außen terminated wird dauert es ebenfalls 10 Sekunden bis zum Beenden was nicht gewünscht ist.

...ein Timer ist keine gute Wahl.:roll:

PS: Diese "Aufgabe" habe ich zum ersten Mal.

Lösungsvorschläge? :wink: (mal sehen ob ihr bessere habt 8-))

Ergänzung zu http://www.delphipraxis.net/72265-th...eleganter.html

Sir Rufo 27. Aug 2014 20:39

AW: Polling im TThread
 
Ein Event vielleicht, wo man 10 Sekunden wartet ob er auslöst und wenn nicht, dann die Aktion ausführt?

Namenloser 27. Aug 2014 20:55

AW: Polling im TThread
 
Das entspricht ja der 2. Variante aus dem verlinkten Beitrag. Ich halte das auch für die richtige Lösung.

haentschman 27. Aug 2014 20:59

AW: Polling im TThread
 
Danke für deine Antwort. Event...wie meinst du das?

mein Vorschlag:
Delphi-Quellcode:
procedure TWorkerPolling.Execute;
var
  StartCount: Cardinal;
  CurrentCount: Cardinal;
begin
  inherited;
  StartCount:= 0;
  while not Terminated do
  begin
    CurrentCount:= GetTickCount;
    if (CurrentCount - StartCount) > conPollingInterval then // conPollingInterval = 10000
    begin
 
     // auszuführender Code

      StartCount:= CetTickCount;
    end;
    Sleep(100); // für Leerlauf
  end;
end;
...auf die 100 ms "Versatz" kann man verzichten.

Zitat:

wo man 10 Sekunden wartet ob er auslöst
...das Warten ist ja das Problem. Auf der einen Seite sollen die Anweisungen nur alle X Milisekunden ausgeführt werden, auf der anderen Seite soll der Thread von Außen sofort beendbar sein. Ist der Thread gerade in der "Verarbeitung" macht er diese natürlich erst fertig und beendet sich dann sofort weil Terminated von außen gesetzt wurde.

Namenloser 27. Aug 2014 21:02

AW: Polling im TThread
 
Zitat:

Zitat von haentschman (Beitrag 1270040)
Event...wie meinst du das?

Delphi-Referenz durchsuchenTEvent

Deine Variante geht natürlich auch, ist aber im Grunde busy-waiting und daher unschöner.

haentschman 27. Aug 2014 21:06

AW: Polling im TThread
 
:P ok...das nächste Mal drücke ich mich geschickter aus. Events benutzte ich reichlich weil ich weis wie es geht... :cheer: Nur im Zusammenhang mit Thread und Auslösen / Warten stand ich auf dem Schlauch...

Uwe Raabe 27. Aug 2014 21:09

AW: Polling im TThread
 
Den Event beim
Delphi-Quellcode:
Terminate
auslösen geht am elegantesten, wenn man
Delphi-Quellcode:
DoTerminate
überschreibt.

haentschman 27. Aug 2014 21:16

AW: Polling im TThread
 
Zitat:

ist aber im Grunde busy-waiting und daher unschöner.
Der Thread soll ja nur den Codeblock abarbeiten... aber nur alle 10 Sekunden. Den Rest macht er nur im Execute die Schleife. (Leerlauf) Warum ist das unschön? Ein Thread läuft doch sowieso im Execute im Kreis und macht immer das Gleiche. :gruebel:
Zitat:

Den Event beim Terminate auslösen geht am elegantesten, wenn man DoTerminate überschreibt.
Vieleicht ist es ja schon zu spät...Aber ich verstehe nicht wie mir ein Event im überschriebenen DoTerminate beim normalen Abarbeiten im Execute hilft. :gruebel:

Namenloser 27. Aug 2014 21:35

AW: Polling im TThread
 
Zitat:

Zitat von haentschman (Beitrag 1270046)
Zitat:

ist aber im Grunde busy-waiting und daher unschöner.
Der Tread soll ja nur den Codeblock abarbeiten... aber nur alle 10 Sekunden. Den Rest macht er nur im Execute die Schleife. (Leerlauf) Warum ist das unschön? Ein Thread läuft doch sowieso im Execute im Kreis und macht immer das Gleiche. :gruebel:

Weil der Thread alle 100ms aufgeweckt wird statt alle 10 Sekunden. Jedes Aufwecken verbrät etwas CPU-Zeit. Dazu kommt noch als weiterer Nachteil die 100ms-Latenz beim Beenden. Letztlich kannst du hier stufenlos zwischen zwei Übeln wählen: kleinere Warteintervalle und damit kleinere Latenz aber dafür höhere CPU-Verschwendung, oder höhere Warteintervalle und damit weniger CPU-Verschwendung aber dafür größere Latenz.

Beides ist aber völlig unnötig, weil das Betriebssystem in Form von Events bereits eine perfekte Lösung anbietet.

himitsu 27. Aug 2014 21:39

AW: Polling im TThread
 
Das einfachste und beste Beispiel, für das eben Genannte, ist die Delay-Funktion von Hagen.
  • möglichst wenig CPU-Last, da nichts gemacht wird, ohne daß etwas ansteht
  • und wenn etwas ansteht, oder wenn die Zeit abgelaufen ist, dann wird sofort reagiert


Alle Zeitangaben in WEZ +1. Es ist jetzt 11:11 Uhr.
Seite 1 von 2  1 2      

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