![]() |
Maximale Threadanzahl / Anzahl der Threads für Programm / Prozeß erhöhbar?
Liebe Delphifreunde!
Zur Zeit bastele ich an einem Algorithmus, der aus dem vollen schöpft und Threads in fast beliebiger Anzahl kreiert. Inzwischen läuft er auch so, wie er soll, fehlt nur noch der Feinschliff, so dieses Problem: Windows verweigert bei irgendeiner Threadanzahl die Erstellung weiterer Threads. Folge ist, daß das Programm stehenbleibt. In meinem Windows 7 64 Bit z.B. wird - anscheinend ist das nicht bei jedem Programm gleich - bei 1.000 < x < 1.500 Threads die Neuerstellung weiterer Threads blockiert. Nun meine Frage: Gibt es irgendeine Möglichkeit (API-Funktion o.a.?), Windows "anzubetteln", daß man die maximale Anzahl dieser Threads für das jeweilige Programm erhöhen kann? Bitte jetzt keine Hinweise, daß das schlechter Programmierstil sei, das ist mir bekannt. Mir geht es nämlich gerade darum, möglichst viel (scheinbar oder tatsächlich) gleichzeitig ablaufen zu lassen und das auch darzustellen, also lebt eine solche Demonstration geradezu von der Anzahl ihrer Threads. Um das Nähkästchen zu öffnen: Das klassische Mergesort läßt sich parallelisieren, und das möchte ich visualisieren, was mir, wie gesagt, inzwischen gelang. Vielen Dank und Gruß Delphi-Laie |
AW: Maximale Threadanzahl / Anzahl der Threads für Programm / Prozeß erhöhbar?
Jeder Thread hat einen Stack und irgendwann ist eben kein Speicher mehr da.
![]() |
AW: Maximale Threadanzahl / Anzahl der Threads für Programm / Prozeß erhöhbar?
Zitat:
|
AW: Maximale Threadanzahl / Anzahl der Threads für Programm / Prozeß erhöhbar?
So, ich habe selbst erfolgreich herumexperimentiert: Man muß die maximale Stackgröße verringern, dann passen auch mehr Threads in den Prozeß (bildlich gesprochen).
|
AW: Maximale Threadanzahl / Anzahl der Threads für Programm / Prozeß erhöhbar?
Für genauere Infos zu den internen Abläufen dazu, siehe
![]() In einem Stackoverflow-Thread habe ich auch noch die Aussage gefunden (auf 32 Bit Prozesse bezogen): Zig: Quasi immer möglich Hunderte: Vermutlich meistens okay, je nach dem Tausende: Fast nie erfolgreich Ich denke, mit deinen 1000-1500 bist du schon recht nah an der praktisch möglichen Grenze für den allgemeinen Fall. |
AW: Maximale Threadanzahl / Anzahl der Threads für Programm / Prozeß erhöhbar?
Danke!
Zitat:
Für mich ein Grund mehr, den Stack nicht zu mögen, der war mir noch nie sympathisch. Jetzt tut sich sogar noch ein Zielkonflikt auf: Threadanzahl versus Rekursion. Was schätze ich deshalb stack-, konkreter rekursionsbefreite Algorithmen, nur, in diesem Falle geht es wohl nicht ohne Stack, und diese "Stellschraube" zur Erhöhung der Threadanzahl war mir vorher auch gar nicht bekannt. |
AW: Maximale Threadanzahl / Anzahl der Threads für Programm / Prozeß erhöhbar?
Zitat:
Der Stack ist einfach eine (ziemlich effiziente) Datenstruktur zur Speicherverwaltung. Zitat:
|
AW: Maximale Threadanzahl / Anzahl der Threads für Programm / Prozeß erhöhbar?
Steht alles in dem verlinkten Artikel.
|
AW: Maximale Threadanzahl / Anzahl der Threads für Programm / Prozeß erhöhbar?
Aussage, die früher oder später hier kommen muss: Was machst du Dir eigentlich Gedanken über die maximal mögliche Thread-Anzahl? Abseits von einem Server, gibt es keine sinnvolle (aka zeitsparende) Anwendung von mehr Threads als CPU-Kernen. Da Du sicherlich nicht der Herr über 1000+ Kerne bist (auf jeden Fall nicht, wenn Du mit Delphi entwickelst), ist das doch allenfalls eine akademische Frage, oder?
Aber falls Du einen wie auch immer gearteten Server entwickelst, solltest Du Dir überlegen eventuell ruhende Verbindungen (=Threads) auszulagern. Dafür gibts sicherlich einen coolen Pattern Namen, der mir aber gerade nicht einfallen will. Sherlock |
AW: Maximale Threadanzahl / Anzahl der Threads für Programm / Prozeß erhöhbar?
Hatt ich mir auch gedacht, dann hab ich den letzten Absatz im ersten Post gelesen ;)
Aber was in dem Kontext sicherlich auch spannend wäre: Zeige, wie sich unterschiedliche Threadanzahlen auf das Laufzeitverhalten auswirken. I.e.: Lass die Simulation mal mit 1, 10, 100, 500, 1000 etc. Threads laufen und vergleiche das Ergebnis. Der größte Trugschluss den ich in Konversationen über Parallelisierung gefunden habe ist, dass mehr Threads mehr Geschwindigkeit bedeuten. Zitat:
Natürlich, es braucht ein gesundes Maß von Threads vs Kernen. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 11:06 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