![]() |
Ist TCustomWinSocket.SendBuf threadsicher?
Hallo!
ich muss hier fremden Quelltext analysieren und frage mich, ob man das Konzept so lassen kann. Manchmal sehr sporadisch, gibts Hänger, und ich bin auf der Suche. Muss aber nicht heißen, dass es daran liegen muss, denn prinzipiell funktioniert das Programm erstmal ohne Probleme. nur beim 24/7 Lauf wohl nicht. also in dem Programm laufen mehrere Threads, und von jedem Thread heraus wird letztendlich die function TCustomWinSocket.SendBuf(var Buf; Count: Integer); ( ScktComp.pas ) aufgerufen. (von ein und dem selben Objekt, das sind meine Bedenken) Nun frage ich mich, ob das threadsicher sein kann? Letztendlich werden ja immer eigene Daten übergeben, und eigentlich sollten die Daten nicht mit denen von anderen Aufrufen kollodieren. Muss ich also eine Threadsichere Jobliste führen, damit ein Thread die Daten holt, und immer nur ein Thread letztendlich SendBuf aufruft, oder gibts bei dem Problem keine Bedenken? vielen Dank! |
AW: Ist TCustomWinSocket.SendBuf threadsicher?
Ein TCP Socket ist vergleichbar mit einem Stream. Wenn nacheinander aus mehreren Threads Daten in den Stream geschrieben wird, kein Problem. Wenn aber während des Schreibens Threadwechsel stattfinden, wird prima Datenmüll erzeugt.
Als Workaround kann man ein TCriticalSection Objekt verwenden, um den schreibenden Zugriff threadsicher zu serialisieren. |
AW: Ist TCustomWinSocket.SendBuf threadsicher?
Zitat:
gemischt wird in dem Projekt in manchen Threads auch alternativ von Indy procedure TIdTCPConnection.WriteBuffer verwendet. kann die das besser? oder trifft dafür die gleiche Aussage zu, wie für TCustomWinSocket.SendBuf? |
AW: Ist TCustomWinSocket.SendBuf threadsicher?
Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 00:12 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