AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

TTask & Synchronize Verständnisproblem

Ein Thema von weisswe · begonnen am 19. Apr 2017 · letzter Beitrag vom 20. Apr 2017
Antwort Antwort
Seite 2 von 2     12
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
9.676 Beiträge
 
Delphi 11 Alexandria
 
#11

AW: TTask & Synchronize Verständnisproblem

  Alt 20. Apr 2017, 08:52
Dafür gibt es ja Prioritäten für Threads und Prozesse. Es macht doch keinen Sinn dann z.B. drei Kerne voll auszulasten und den vierten leer laufen zu lassen nur für den Fall, dass er benötigt wird...
Sebastian Jänicke
AppCentral
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.499 Beiträge
 
Delphi 12 Athens
 
#12

AW: TTask & Synchronize Verständnisproblem

  Alt 20. Apr 2017, 10:44
Gerade die Downloads sind ja in der Regel nicht sonderlich prozessorintensiv. Solange das Warten auf den Empfang des nächsten Datenpakets bzw. dessen Schreiben auf Platte nicht mit einem Busy-Wait implementiert ist, regelt sich das eigentlich ganz von selber.

Andererseits geht auch hier nichts über reale Messungen.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.144 Beiträge
 
Delphi 10.3 Rio
 
#13

AW: TTask & Synchronize Verständnisproblem

  Alt 20. Apr 2017, 11:32
Warum sollte man denn das Maximum geringer setzen wollen als die Anzahl der CPU Kerne?
Eben... Es gab mal eine Theorie, dass auf einem mobilen Gerät weniger Strom verbraucht wird, wenn man nicht alle Kerne benutzt, aber ich denke das stimmt nicht.

Aber für einen Download gelten andere Regeln, z.B. wenn der Server nur 1x die IP zu lässt.

Je nach Server und Bandbreite sind ca. 4 Thread optimal (bei großen Dateien) bei Tausenden kleinen sind mehr Thread besser...

Für den Download und die Verarbeitung der Daten empfehle ich sowas sie meine Parallel-Multithreading-Pipeline.

Wie man es implementiert ist fast egal - man kann auch einfach "nur" eine Anzahl von Workerthreads per Hand erzeugen und so die Daten verarbeiten.

Mavarik
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.499 Beiträge
 
Delphi 12 Athens
 
#14

AW: TTask & Synchronize Verständnisproblem

  Alt 20. Apr 2017, 11:41
Aber für einen Download gelten andere Regeln, z.B. wenn der Server nur 1x die IP zu lässt.
Wer sagt denn, daß die Downloads alle von demselben Server kommen? Aber selbst wenn, dann warten die anderen Download-Threads auf den freiwerdenden Socket und benötigen dabei vermutlich auch keine CPU-Zeit. Dafür skaliert das System automatisch sobald mehrere gleichzeitige Downloads möglich sind. Ich sehe immer noch keinen Vorteil darin, die Anzahl der Threads zu begrenzen.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.144 Beiträge
 
Delphi 10.3 Rio
 
#15

AW: TTask & Synchronize Verständnisproblem

  Alt 20. Apr 2017, 11:50
Wer sagt denn, daß die Downloads alle von demselben Server kommen?
Es war ja nur ein Beispiel.

Aber selbst wenn, dann warten die anderen Download-Threads auf den freiwerdenden Socket und benötigen dabei vermutlich auch keine CPU-Zeit.
Das "glaube" ich nicht... Server die so eine Begrenzung haben liefert i.d.R. eine Fehlerseite. Bedeutet alle Threads die nachträglich gestartet werden laufen in leere und der download wird unproduktiv.

Aber vielleicht sollte man diese Theorien mal gegen ein Testsystem laufen lassen...

Mavarik
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.499 Beiträge
 
Delphi 12 Athens
 
#16

AW: TTask & Synchronize Verständnisproblem

  Alt 20. Apr 2017, 11:57
Ich stelle gerade fest, daß wir uns ziemlich weit vom ursprünglichen Thema entfernt haben
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.144 Beiträge
 
Delphi 10.3 Rio
 
#17

AW: TTask & Synchronize Verständnisproblem

  Alt 20. Apr 2017, 12:02
Ich stelle gerade fest, daß wir uns ziemlich weit vom ursprünglichen Thema entfernt haben
Stimmt... Die Frage war ja auch eigentlich mit #2 beantwortet...
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12


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 21:52 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 by Thomas Breitkreuz