![]() |
wait prozedur bewirkt vollständige cpu auslastung
tach zusammen,
ich benutze in einem service folgende wait prozedure:
Delphi-Quellcode:
diese schluckt aber leider 100% cpu last. was habe ich falsch gemacht?
procedure wait;
var res : Cardinal; s : String; begin repeat Res := MsgWaitForMultipleObjects(2, hndlArr, false, 3600000, QS_ALLINPUT); if (Res = $ffffffff) then RaiseLastOSError; if Res = 1 then ForceUpdate := true; s := IntToStr(Res); until (Res = WAIT_OBJECT_0) or (Res = WAIT_TIMEOUT) or (Res = 1); end; ich hoffe einige leute haben verbesserungsvorschläge :) ps: res = 1 tritt auf, wenn eins der beiden events aus dem handlearray ausgelöst werden mfg Jonny |
Re: wait prozedur bewirkt vollständige cpu auslastung
Du hast den Code unterschlagen, der das Array hndlArr befüllt.
Hat der Service eine Benutzeroberfläche? Falls nicht, gibt es keinen Grund für QS_ALLINPUT. |
Re: wait prozedur bewirkt vollständige cpu auslastung
Bringt in der Schleife viellecht ein Application.ProcressMessages was? :gruebel:
|
Re: wait prozedur bewirkt vollständige cpu auslastung
Hallo,
Zitat:
Gruß xaromz |
Re: wait prozedur bewirkt vollständige cpu auslastung
|
Re: wait prozedur bewirkt vollständige cpu auslastung
servus,
also mein service hat keine oberfläche, und das hndlArr wird wie folgt befüllt:
Delphi-Quellcode:
den vorgeschlagene thread lese ich mir gleich mal durch.
hndlarr[0] := Event1.Handle;
hndlarr[1] := Event2.Handle; mfg Jonny |
Re: wait prozedur bewirkt vollständige cpu auslastung
kurzer nachtrag:
ich habe mir gerade den vorgeschlagenen thread von klaus durchgelesen, aber auch die folgende prozedur
Delphi-Quellcode:
bringt 100% cpu auslastung
procedure Delay(Milliseconds: Integer);
var Tick: DWord; Event: THandle; begin Event := GetCurrentThread; Tick := GetTickCount + DWord(Milliseconds); while Milliseconds > 0 do case MsgWaitForMultipleObjects(1, Event, False, Milliseconds, QS_ALLINPUT) of WAIT_TIMEOUT: Exit; WAIT_OBJECT_0: WriteLn('Fails'); else begin Application.ProcessMessages; Milliseconds := Tick - GetTickcount; end; end; end; |
Re: wait prozedur bewirkt vollständige cpu auslastung
Deine letzte Funktion bringt bei mir in einer Consolenanwendung auch 100% CPU Last.
Die folgende Funktion bringt bei eine CPU Last von 3-4%.
Delphi-Quellcode:
Grüßeprocedure Delay(Milliseconds: Integer); {by Hagen Redmann} var Tick: DWORD; Event: THandle; begin Event := CreateEvent(nil, False, False, nil); try Tick := GetTickCount + DWORD(Milliseconds); while (Milliseconds > 0) and (MsgWaitForMultipleObjects(1, Event, False, Milliseconds, QS_ALLINPUT) <> WAIT_TIMEOUT) do begin Application.ProcessMessages; Milliseconds := Tick - GetTickCount; end; finally CloseHandle(Event); end; end; Klaus |
Re: wait prozedur bewirkt vollständige cpu auslastung
moin klaus,
ich kann leider nicht in meinem service application.processmessages benutzen :( mfg Jonny |
Re: wait prozedur bewirkt vollständige cpu auslastung
Nun, von Services habe ich keine Ahnung (hab' noch nie einen programmiert) deshalb jetzt
meine etwas dümmliche Frage: Geht es auch nicht wenn Du die Unit Forms einbindest? Grüße Klaus |
Re: wait prozedur bewirkt vollständige cpu auslastung
habe ich gerade versucht, dass geht *g*. aber leider bringt der code:
Delphi-Quellcode:
auch wieder volle cpu auslastung :(
procedure Delay(Milliseconds: Integer);
{by Hagen Redmann} var Tick: DWORD; // Event: THandle; begin // Event := CreateEvent(nil, False, False, nil); try Tick := GetTickCount + DWORD(Milliseconds); while (Milliseconds > 0) and (MsgWaitForMultipleObjects(2, hndlArr, False, Milliseconds, QS_ALLINPUT) <> WAIT_TIMEOUT) do begin Application.ProcessMessages; Milliseconds := Tick - GetTickCount; end; finally // CloseHandle(Event); end; end; mfg Jonny |
Re: wait prozedur bewirkt vollständige cpu auslastung
Ruf doch einfach mal in deinem ursprüngluichen Code Sleep(1) auf.
|
Re: wait prozedur bewirkt vollständige cpu auslastung
moin luckie,
trotz sleep(1) immer noch volle cpu auslastung... mfg Jonny |
Re: wait prozedur bewirkt vollständige cpu auslastung
Zwei Fragen:
1. Rufst du die Routine in einem Thread auf? 2. Warum gibst du in einem Beispiel den aktuellen Thread (GetCurrentThread) als das Objekt an, auf das gewartet werden soll? |
Re: wait prozedur bewirkt vollständige cpu auslastung
@Jonny:
Ist das noch der gleiche Code den du verwendest ? Nein: du kommentierst Zeilen aus die die Funktion vollständig verändern.
Delphi-Quellcode:
So funktioniert das wunderprächtig, in einem normalem Prozess wie angedacht. Das Event so zu benutzen ist essentiell, es ist nämlich ein niemals signalsierendes Event und darauf baut der Code aktiv auf.
procedure Delay(Milliseconds: Integer);
{by Hagen Reddmann} var Tick: DWORD; Event: THandle; begin Event := CreateEvent(nil, False, False, nil); try Tick := GetTickCount + DWORD(Milliseconds); while (Milliseconds > 0) and (MsgWaitForMultipleObjects(1, Event, False, Milliseconds, QS_ALLINPUT) <> WAIT_TIMEOUT) do begin Application.ProcessMessages; Milliseconds := Tick - GetTickCount; end; finally CloseHandle(Event); end; end; Willst du das abändern dann unter 4 Bedingungen:
Delphi-Quellcode:
1.) ein Service wie deiner hat keinen Message Queue
procedure Delay(Milliseconds: Integer);
var Tick: DWORD; begin Tick := GetTickCount + DWORD(Milliseconds); while Milliseconds > 0 do begin case WaitForMultipleObjects(2, hndlArr, False, Milliseconds, QS_ALLINPUT) of WAIT_OBJECT_0 +0 : begin // Event Nummer 1 signalisiert end; WAIT_OBJECT_1 +1 : begin // Event Nummer 2 signalisiert end; WAIT_TIMEOUT: begin // nothing todo Exit; end; else begin // Fehler !! end; end; Milliseconds := Tick - GetTickCount; end; end; 2.) MsgWaitFor...() benötigt einen Message Queue, ergo wird WaitForMultipleObjects() benutzt 3.) du musst bei vorzeitiger Rückkehr von WaitFor..() auch die signalisierenden Events abprüfen. Besonders wenn diese Events sich nur manuell zurücksetzen lassen. Du hast ja eben nichts darüber ausgesagt was für Events das sind und wie sie signalisiert/resetet werden 4.) überpüfe nun ob der obige Code permanent in WAIT_OBJECT_0 oder WAIT_OBJECT_0 +1 rein springt. Sollte dies der Fall sein so ist dein Event Handling falsch. Eventuell musst du die Event mit ResetEvent() zurücksetzen. Alles in allem kann ich dir garantieren das wenn die Events korrekt benutzt werden die CPU Auslastung entsprechend der Häufigkeit des Auslösens der Events absinken wird. Sind diese natürlich permanent signalisiert so beträgt die CPU Auslastung auch 100%. Der obige Code ist dermaßen trivial das ein Fehler auszuschließen ist. Wenn also die CPU Auslastung immer noch 100% ist so wird es mit großer Wahrscheinlichkeit ein Fehler in deinem restlichen Code sein (den wir ja nicht kennen). Gruß Hagen |
Re: wait prozedur bewirkt vollständige cpu auslastung
so, mit dem letzten code klappt alles hervorragend,
jedoch sind noch 3 veränderungen zu machen:
Delphi-Quellcode:
so liet die prozessorauslastung bei 0% und ich bin glücklich.
procedure Delay(Milliseconds: Integer);
var Tick: DWORD; begin Tick := GetTickCount + DWORD(Milliseconds); while Milliseconds > 0 do begin case WaitForMultipleObjects(2, @hndlArr, False, Milliseconds) of WAIT_OBJECT_0 +0 : begin // Event Nummer 1 signalisiert end; WAIT_OBJECT_0 +1 : begin // Event Nummer 2 signalisiert end; WAIT_TIMEOUT: begin // nothing todo Exit; end; else begin // Fehler !! end; end; Milliseconds := Tick - GetTickCount; end; end; vielen dank an alle mfg Jonny |
Alle Zeitangaben in WEZ +1. Es ist jetzt 20:58 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