![]() |
[TIdTCPServer] & TTimer Ablaufproblem
Hallo zusammen,
ich habe in einem Dienst die beiden Komponenten TIdTCPServer und TTimer. Der Timer wird gleich in der Procedure OnServiceStart gestartet, wenn eine Verbindung zur Datenbank besteht. Dieser Timer prüft alle 30 Sekunden ab, ob in einem bestimmten Verzeichnis neue Dateien sind. Während der Überprüfung ist der Timer ausgeschaltet. Zusätzlich prüft, der TIdTCPServer alle 500ms ob ein neuer Befehl an den Server gesendet wurde. TIdTCPServer-OnExecute-Methode :
Delphi-Quellcode:
TTimer OnTimer-Methode:
procedure TSvcMainForm.IdTCPServer_MainExecute(AContext: TIdContext);
begin try // To repeat after 500ms to show for new transmitted data from the client newData := AContext.Connection.Socket.ReadLn(#$A, 500); except newData := ''; end; if Trim(newData) <> '' then begin {... weitere Befehle werden abgearbeitet ...} end; end;
Delphi-Quellcode:
Befindet sich das Programm nun in der OnTimer - Methode, wird alles entsprechend abgearbeitet. Wird aber zum gleichen Zeitpunkt die OnExecute-Methode des TIdTCPServer aufgerufen, dann wird aus irgendeinem Grund die OnTimer-Methode nichtmehr weiter abgearbeitet und der Dienst geht in den Leerlauf. Währe es hier besser angebracht, durch den Timer einen Thread zu starten, der dann abgearbeitet wird ?
procedure TSvcMainForm.Timer_SpoolerTimer(Sender: TObject);
var FileList: TStringList; SR: TSearchRec; begin Timer_Spooler.Enabled := False; FileList := TStringList.Create; FileList.Clear; try if FindFirst(LogPath + '*.xml', faAnyFile, SR) = 0 then begin repeat if (SR.Attr <> faDirectory) then begin FileList.Add(SR.Name); end; until FindNext(SR) <> 0; FindClose(SR); end; if FileList.Count > 0 then WriteDataToDB(LogPath, FileList); finally FileList.Free; end; Timer_Spooler.Enabled := True; end; |
AW: [TIdTCPServer] & TTimer Ablaufproblem
Ich kann in dem gezeigten Code keine Fehlerursache sehen. Vielleicht ein Synchronisations-Problem? (IdTCPServer_MainExecute wird ja nicht im Hauptthread bzw. im gleichen Thread wie das Timeereignis ausgeführt)
|
AW: [TIdTCPServer] & TTimer Ablaufproblem
Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 18:23 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