Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Algorithmen, Datenstrukturen und Klassendesign (https://www.delphipraxis.net/78-algorithmen-datenstrukturen-und-klassendesign/)
-   -   Ist das Thread-Sicher? (https://www.delphipraxis.net/156883-ist-das-thread-sicher.html)

emteg 18. Dez 2010 22:08

Ist das Thread-Sicher?
 
Ich habe hier eine Methode, die zum Versenden von einem String über TCP einen TIdThread verwendet. Nachdem der Thread beendet wurde, gebe ich der Anwendung über entsprechende Events rückmeldung, so dass das Ergebnis in einem Memo angezeigt wird.

Delphi-Quellcode:
procedure TConnector.Send(const AMessage, AHost: String);
var p: integer;
begin
  p := FPort;

  with TSendThread.Create do
  begin
    FreeOnTerminate := true;
    OnTerminate := ThreadTerminated;
    FHost := AHost;
    FMessage := AMessage;
    FPort := p;
    Start;
  end;
end;

procedure TConnector.ThreadTerminated(ASender: TObject);
var s: String;
begin
  s := TIdThread(ASender).TerminatingException;
  if length(s) = 0 then
    DoOnSent(TSendThread(ASender).FMessage, TSendThread(ASender).FHost)
  else
    DoOnSendError(TSendThread(ASender).FMessage, TSendThread(ASender).FHost, s);
end;
Hier noch der Code von TSendThread:

Delphi-Quellcode:
  TSendThread = class(TIdThread)
  private
    FMessage, FHost: String;
    FPort: integer;
  public
    procedure Run; override;
  end;

procedure TSendThread.Run;
begin
  with TIdTCPClient.Create(nil) do
  try
    Host := FHost;
    Port := FPort;
    ConnectTimeout := 1000;
    Connect;
    IOHandler.WriteLn(FMessage);
  finally
    Disconnect;
    Free;
  end;
  Stop;
end;
Muss ich noch irgendwo einen Synchronize-Aufruf einbauen, oder geht das schon so? Denn die Behandlung der Ergebnise findet ja erst nach ende des Threads statt.

Bei einem Test funktioniert zwar alles problemlos, das war aber in einer sehr einfachen Test-Applikation und noch nicht im endgültigen Kontext.

Bummi 18. Dez 2010 23:09

AW: Ist das Thread-Sicher?
 
Zu den Indys kann ich mich nicht äußern, aber der Code im OnTerminate eines Threads wird bereits Synchronized aufgerufen.


Alle Zeitangaben in WEZ +1. Es ist jetzt 07: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