AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi Thread Vs Timer !!! Wievile Threads sind zu viel ?
Thema durchsuchen
Ansicht
Themen-Optionen

Thread Vs Timer !!! Wievile Threads sind zu viel ?

Ein Thema von DataCool · begonnen am 14. Sep 2003 · letzter Beitrag vom 16. Sep 2003
Antwort Antwort
Seite 1 von 3  1 23      
Benutzerbild von DataCool
DataCool

Registriert seit: 10. Feb 2003
Ort: Lingen
909 Beiträge
 
Delphi 10.3 Rio
 
#1

Thread Vs Timer !!! Wievile Threads sind zu viel ?

  Alt 14. Sep 2003, 01:31
Hi Leute,

ich sitze gerade an einem Prog, das ne ganze Menge im Hintergrund macht und genauso viel im Vordergrund.

Ich habe im Moment :

4 Timer

12 Threads

einen IdHttp-Server, der natürlich auch ein paar Threads aufmacht

einen IdTcpServer, der ebenfalls mehere Threads erzeugt

2 x TWebBrowser, die komischerweise jeweils 4 Threads erzeugen, warum

Wenn ich jetzt meine App starte sehe ich im Task-Manager, das um die 30 Threads dazu kommen, ist das schon hart an der Grenze ?

Meine App läuft normalerweise mit 5-8 % CPU-Last, aber neuderdings von Zeit zu Zeit(also absolut sporadisch) steigt die CPU-Last auf 98 % und legt alles lahm.

Das führt mich zu der Frage soll ich aus den Threads Timer machen bzw. aus den Timern Threads ?!

Ok, Timer sind ungenau !
Aber haben Threads die höhere Systembelastung ?

Im Moment verwende ich die Timer für die absolut "unwichtigen" regelmäßigen Aufgaben z.B. Server pingen, um "Ich bin noch da" zu sagen.

Und für die Aufgaben wo es um Geschwindigkeit geht Threads, die teilweise
alle 50 ms agieren.

Aber zurück zum Themaq :

Alles Threads oder Alles Timer ???

Gruß Data

P.S. Wenn ich nur Timer verwende, wird das OnTimer-Ereignis jedesmal vom Main-Thread mit syncronize aufgerufen ?
Der Horizont vieler Menschen ist ein Kreis mit Radius Null, und das nennen sie ihren Standpunkt.
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#2

Re: Thread Vs Timer !!! Wievile Threads sind zu viel ?

  Alt 14. Sep 2003, 04:44
Auf was für eienm System soll das ganze Laufen? Für Consumer Windows könnte es schon kritisch werden.

Was die CPU Last angeht: So lange deine Threads Rechenzeit abgeben, wenn sie von anderen Prozessen gebraucht wird, ist alles in Ordnung. Warum sollen sie nicht 98% der CPU Zeit nutzen. Lass sie arbeiten, dafür hast du sie gekauft.

Welche Priorität haben deine Threads?

Was sich auch günstig auswirkt ist eien Sleep(0) am Ende jeder Threadschleife, dadurch geben sie nicht mehr benötigte Rechenzeit freiwillig ab.

Die Timer im primären Thread mußt / kannst du nicht synchronisieren. Desweiteren würde ich dir raten auf Threads umzusteigen, da Timer deine Anwendung immer lahm legen, so lange das Timer Ereigniss abgearbeitet wird.

Und wichtig: Immer synchronisieren entweder mit der Synchronize-methode des Thread-Objektes, CriticalSections oder atomare Funktionen wie die InterLockedExchange Funktionen.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von DataCool
DataCool

Registriert seit: 10. Feb 2003
Ort: Lingen
909 Beiträge
 
Delphi 10.3 Rio
 
#3

Re: Thread Vs Timer !!! Wievile Threads sind zu viel ?

  Alt 14. Sep 2003, 23:19
Hi Luckie,

die App soll auf alle noch gängigen Windows-Systemen laufen, auch Win98 u. WinME.

Zu den Threads :

Die meisten laufen im Hintergrund mit normaler bzw. niedriger Priorität und sollen nur in Intervallen a 60 bzw. 75 Sek. einen Http-Request(auch mit Indy) absetzen und anhand der Antwort Gui-Elemente aktualisieren, was ich auch mit Syncronize mache.

Hier mal ein Beispiel wie dir meisten meiner Threads ablaufen ;
Code:
procedure TAdminListThread.Execute;
Var iWait : Longint;
begin
   while not Terminated do begin
      DoRequest;
      //
      iWait := 0;
            // cIntervall ist in diesem Fall 75000
      While (not Terminated) and (iWait < cIntervall) do begin
         inc(iWait,500);
         sleep(500);
      end;
   end;
end;
Was mich nur wundert bzw. ärgert :
Bis vor kurzem hatte ich eine Version die einwandfrei lief und auch unter extremer Belastung nur max. 20% der CPU ausgelastet hat.

Dann habe ich wirklich nur ein paar Kleinigkeiten geändert, so unrelevate Sachen das ich die Änderungen nicht mal mehr aufzählen kann
Ich glaube ich habe einen Intervall von 140000 Sek. auf 120000 Sek geändert, zwei Timer auf Formulare gesetzt, die ich nur dynamisch erzeuge und danach wieder freigebe.
Und zwei drei andere Kleinigkeiten die mir aber nicht mehr einfallen

Das schlimme ist das ich normalerweise bei jeder Version/Release bevor ich sie hoch lade und den usern zur verfügung stelle, einmal komplett den Quellcode mit Version sichere.

Das habe ich vor lauter Stress leider nicht getan, d.h. die letzte Version wo dieses Phänomen der CPU-Belastung nicht auftrat ist schon etwas älter

Bei der ganzen App geht es um eine Live-Bildübertragung mit eingebauten Chat(deshalb die 2 TWebbrowser instanzen)
Die hauptsächlichen Zeitkritischen Threads sind die beiden Bildübertragungsthreads :
1. Ein WebServer mit IdHttpServer
2. Ein normaler IdTcpServer

beide greifen das Bild einer Webcam/Videokamera syncronisiert vom Video-Treiber ab.

Dann gibt es noch zwei Timer die in Abständen von 100 ms folgendes tun :
Der eine schickt geschriebene Chat-Texte, die erst in einer Stringlist zwischengespeichert werden, zu den Clients.
Der andere Timer stellt die Erhaltenen Chat-Texte dar.
Er erstellt davor einen lokalen HTML-File der dann vom TWebbrowser aufgerufen wird.

Hat irgentjemand eine Idee, durch welche Umstände plötzlich eine solch schlechte Performance verursacht werden könnte ?

Oder ist jemand im Decompilen und asm so gut, das er mir die UNterschiede von meiner alten und neuen App nennen kann ?

Danke schonmal im vorraus für jede Hilfe, weiß gerade wirklich nicht weiter

Data
Der Horizont vieler Menschen ist ein Kreis mit Radius Null, und das nennen sie ihren Standpunkt.
  Mit Zitat antworten Zitat
anku

Registriert seit: 13. Sep 2003
51 Beiträge
 
#4

Re: Thread Vs Timer !!! Wievile Threads sind zu viel ?

  Alt 15. Sep 2003, 01:49
Also die Anzahl sollte noch nicht so kritische sein. Windows 2k und höher ist ja auf Multithreading ausgelegt. Bei mir laufen meistens so 250 Threads insgesamt. Solange die nicht zuviel CPU Zeit verbraucht ist doch alles im grünen Bereich.

mfg
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#5

Re: Thread Vs Timer !!! Wievile Threads sind zu viel ?

  Alt 15. Sep 2003, 02:10
Windows 9x/ME ist auch auf Multithreading "ausgelegt" wie du es bezeichnest. Nur kann Windows9x/ME nicht so viele Ressourcen verwalten. das dein Windows2000 System 250 Threads verkraften kann, sagt nichts über Windows 9x/ME aus. das sind zwei total verschiedene Paar Schuhe.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von DataCool
DataCool

Registriert seit: 10. Feb 2003
Ort: Lingen
909 Beiträge
 
Delphi 10.3 Rio
 
#6

Re: Thread Vs Timer !!! Wievile Threads sind zu viel ?

  Alt 15. Sep 2003, 10:52
bei mir laufen meistens 300-350 Threads und die cpu ist nicht belastet(Win XP Prog. 1.8 Ghz, 1 GB Ram)

Noch ne Frage zum Timer :

Der Timer benutzt ja die WM_Timer Message, läuft das OnTimer-Ereigniss wirklich in einem seperaten Thread parallel zum Hauptthread ?

Was schluckt mehr Ressourcen ein Thread mit Priorität tpLowest im vergleich zum Timer ?

Data
Der Horizont vieler Menschen ist ein Kreis mit Radius Null, und das nennen sie ihren Standpunkt.
  Mit Zitat antworten Zitat
Chewie

Registriert seit: 10. Jun 2002
Ort: Deidesheim
2.886 Beiträge
 
Turbo Delphi für Win32
 
#7

Re: Thread Vs Timer !!! Wievile Threads sind zu viel ?

  Alt 15. Sep 2003, 12:21
Ein Timer funktioniert ja folgendermaßen: Wenn in der Nachrichtenschleife des Hauptfensters eine WM_TIMER-Nachricht auftritt, wird die Prozedur, auf die Timer.OnTimer zeigt, ausgeführt, und zwar in einem extra Thread.
Die Prozessorauslastung dürfte relativ gleich sein, der Unterschied ist eben, dass sich die WM_TIMER-Nachtichten sehr verzögern können, wenn du in einem Thread innerhalb des Programms einen Timer einsetzt, kannst du (fast) völlige Synchronisation erhalten.
Martin Leim
Egal wie dumm man selbst ist, es gibt immer andere, die noch dümmer sind
  Mit Zitat antworten Zitat
neolithos

Registriert seit: 31. Jul 2003
Ort: Dresden
1.386 Beiträge
 
Delphi 7 Architect
 
#8

Re: Thread Vs Timer !!! Wievile Threads sind zu viel ?

  Alt 15. Sep 2003, 12:27
Zitat von chewie:
wird die Prozedur, auf die Timer.OnTimer zeigt, ausgeführt, und zwar in einem extra Thread.
Muss ich das Verstehen! Du hast noch nie eine nonVCL Anwendung geschrieben! Oder?

Der TTimer erzeugt ein Fenster, welches die WM_TIMER Nachricht erhält. Diese Procedure wird nicht in einen extra Thread ausgeführt, sondern in dem Thread in dem sich der Timer befindet.

Um Resourcen (Fenster-Handles und Speicher) zu sparen, verwende ich Timer nur über

Delphi-Quellcode:
SetTimer
KillTimer
WM_TIMER
- ciao neo -
Es gibt niemals dumme Fragen, sondern nur dumme Antworten!
  Mit Zitat antworten Zitat
Benutzerbild von DataCool
DataCool

Registriert seit: 10. Feb 2003
Ort: Lingen
909 Beiträge
 
Delphi 10.3 Rio
 
#9

Re: Thread Vs Timer !!! Wievile Threads sind zu viel ?

  Alt 15. Sep 2003, 12:47
Ok, d.h. auf jeden Fall besser ein Thread mit niedriger Priorität verwenden als ein Timer.

So müßte die Belastung in etwa gleich seien, nur bei einem Thread kann ich mir sicher sein das es wirklich ein Thread ist und der Thread-Code wirklich "parallel" zum Haupt-Thread ausgeführt wird.

Data
Der Horizont vieler Menschen ist ein Kreis mit Radius Null, und das nennen sie ihren Standpunkt.
  Mit Zitat antworten Zitat
Chewie

Registriert seit: 10. Jun 2002
Ort: Deidesheim
2.886 Beiträge
 
Turbo Delphi für Win32
 
#10

Re: Thread Vs Timer !!! Wievile Threads sind zu viel ?

  Alt 15. Sep 2003, 12:48
Ich hab zwar schon nonVCL-Anwendungen geschrieben, allerdings dort noch nie einen Timer verwendet.

Sehr komisch, ich hätte schwören können, dass die Berechnung in einem extra Thread abliefe. Anscheinend hat mich da mein Gedächtnis betrogen, aber ich hätte schwören können, dass der Prozess 2 Threads hat, sobald ich den Timer aktiviere.
Martin Leim
Egal wie dumm man selbst ist, es gibt immer andere, die noch dümmer sind
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 10:39 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