![]() |
Threads arbeiten nur auf einem Kern
Hallo,
Ich habe es jetzt endlich geschafft meinen Code mit Threads zu parallelisieren, da taucht das nächste Problem auf: Meine zwei erzeugten Threads arbeiten nur auf einem CPU-Kern anstatt alle zu verwenden. Ich arbeite nicht (oder nur sehr wenig) mit Synchonize. Die Threads sind ansonsten identisch und die Execute Funktion bearbeitet ne Menge unterschiedlicher Operationen (erzeugen und zerstören von Objekten, schleifen, String Operationen, usw... da ist alles dabei). Tausche ich die Execute durch eine Schleife, die einfach einen Integer hoch zählt, funktioniert es hingegen und jeder Thread lastet einen Kern voll aus. Meine Frage ist: Warum? Und was kann ich dagegen machen? Ich habe ![]() |
AW: Threads arbeiten nur auf einem Kern
Hi,
ich lege die threads selbst auf andere Kerne, das geht so: if JvComputerInfoEx1.CPU.ProcessorCount > 1 then SetThreadAffinityMask(ThreadEx1.Handle,2); |
AW: Threads arbeiten nur auf einem Kern
Das bewirkt lediglich, dass zwei Kerne jeweils zur Hälfte ausgelastet sind. Sie laufen immer noch nicht "echt" parallel.
|
AW: Threads arbeiten nur auf einem Kern
Gibt es vielleicht andere, ressourcen, die nur exklzusiv benutzt werden können?
Poste mal den Code der Execute Methode... |
AW: Threads arbeiten nur auf einem Kern
Der Speichermanager Synchronisiert auch noch einiges ... kann sein, daß (wenn du sehr viele Speicheranfragen/-freigaben hast, im Verhältnis zum restlichen Code) da auch mehr in ein Thread reinsynchronisiert wird.
(der kann halt auch nicht alles paralell machen, wenn er eine gemeinsame Speicherverwaltung nutzt) Wann wurde nochmal FastMM in Delphi integriert? (bin mir nicht sicher, ob dieses erst ab Delphi 2006 drinnen ist) Der alte Delphi-Speichermanager konnte immer nur einen Thread geichzeitig bediehnen. Bei mehreren gleichzeitigen Anfragen, mußten andere warten. FastMM versucht (ich glaub 3 Thread) gleichzeitig innerhalb verschiedenster Speichergrößen zu unterstützen, bei einer Speicheranfrage (also eine 10 Byte-Anfrage und Eine nach 10.000 Byte werden sich nicht behindern). Ist ein Speicherblock grade blockiert, dann versucht er sofort den Nächsten und wenn Dieser es auch ist, dann noch eines weiter. Ist alles blockiert, dann muß ebenfalls gewartet werden. ABER, bei Speicherfreigaben und bei Reallocierungen muß er genau auf einen bestimmten Block zugreifen und das kann nur für einen einzigen Thread gleichzeitig bewerkstelligt werden. |
AW: Threads arbeiten nur auf einem Kern
Das dürfte schwierig werden. Der Code erstreckt sich bestimmt über 10 verschiedene Klassen. Und mein Chef würde es, denke ich, nicht gerne sehen, wenn ich den Code hier einfach poste:wink:
Nenn doch bitte mal ein paar Beispiele für Ressourcen. Also Hardware-Ressourcen benutze ich da keine. Die meißte Zeit rechnet da ![]() Das interessante ist ja, dass er keinen deut über einen Kern hinaus kommt. Würde ich irgendwo eine exklusive Ressource verwenden könnte er ja wenigstens den Rest des Codes parallel abarbeiten und wäre so etwas über der Kapazität von einem Kern, was er aber nicht ist. Ich verwende Delphi 2010, da ist FastMM drinn. "Speicher" ist eine exklusive Ressource, aber ich mache teilweise auch einfach nur Berechnungen, die keinen Speicher allozieren. |
AW: Threads arbeiten nur auf einem Kern
Auf welche Priorität sind denn die Threads gesetzt?
Ich habe die vage Vermutung, dass das gar nicht mal an Delphi liegt, sondern an Windows selbst. Gibt es einen Unterschied und der Auslastungs-Verteilung, wenn du den Threads z.B. tpHigher oder tpHighest gibst? Vielleicht hilft auch gfolgender Artikel: ![]() Interessant ist vielleicht auch folgender Artikel über FastMM, der vielleicht genau in diese Kategorie fällt?: ![]() Zumindest folgende Kommentare daraus könnte vielleicht nützlich sein: Zitat:
Zitat:
|
AW: Threads arbeiten nur auf einem Kern
Gab es nicht in Delphi *und* im FastMM eine Einstellung wie
Delphi-Quellcode:
Beim FastMM ist es in der Options Include mit drin.
Multithreaded := true;
isMultithreaded := true; |
AW: Threads arbeiten nur auf einem Kern
@generic: Wenn man mit TThread einen Thread erstellt, dann wird diese Variable automatisch auf True gestellt.
(die WinAPI wie CreateThread macht sowas natürlich nicht, da es diese Delphi-Variable nicht kennen kann) |
AW: Threads arbeiten nur auf einem Kern
Leider hatte weder IsMultiThread noch NeverSleepOnThreadContention einen Effekt.
Da die CPU Auslastung auf genau 50% (also ein Kern voll ausgelastet) verweilt, wenn die Threads laufen, glaube ich auch nicht, dass es daran liegt, dass FastMM langsam ist. Hat noch jemand eine Idee? |
Alle Zeitangaben in WEZ +1. Es ist jetzt 14:34 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