Es sind bereits mehrfach Artikel über Anwendungsentwicklung mit Multithreading erschienen, unter anderem über das Schreiben von Multithreaded Code in VB.NET und über die (mit .NET 4 ausgelieferten) Parallel Extensions, jedoch nie mit Code-Beispielen. Nachfolgend werden einige Funktionen der Parallel Extensions in .NET 4 mit Code-Beispielen hervorgehoben. Der Code stammt aus einer Präsentation zu Parallel Extensions. Es handelt sich um ein großes Gebiet, daher konzentriert sich dieser Artikel auf die sogenannte imperative Parallelität, wie sie die Parallel-Klasse (die Teil des Namensraums System.Threading.Tasks ist) implementiert.
Die Parallel-Klasse
Die statische Parallel-Klasse enthält drei äußerst nützliche Methoden: For, ForEach und Invoke. For und ForEach operieren auf der Grundlage eines Action-Objekts; Invoke arbeitet mit einem Array von Actions. For und ForEach simulieren die Funktionalität der Loops, nach denen sie benannt sind.
Für alle drei Methoden ist die Reihenfolge der Ausführung nicht garantiert. Die Ausführung kann vollständig zufällig, der Reihe nach oder teilweise der Reihe nach erfolgen. Wenn der Code eine Ausführung in einer bestimmten Reihenfolge erfordert, ist er nicht gut für parallele Operationen geeignet. Zuerst soll nun Parallel.For betrachtet werden.
Eine normale For-Schleife sieht üblicherweise etwa wie folgt aus:
Diese Schleife gibt für jedes Element im Bereich zwischen startNumber und endNumber die Fibonacci-Zahlen aus. Ganz typisch oder? Wenn man dies nun mit dem herkömmlichen Threading-Modell erreichen wollte, wäre in Bezug auf den Inhalt der Schleife viel Arbeit nötig. Man müsste Threads erstellen, diese mit Delegation auf eine Funktion starten und vielleicht noch Code mit einem Semaphore ergänzen, um die Zahl der aktiven Threads auf die Zahl der logischen CPU-Kerne im System zu begrenzen.
In einem anderen, fast identischen Beispiel nimmt der Code um diese Schleife von 18 Code-Zeilen (einschließlich Whitespace und Klammern) auf 79 LOC (Lines of Code) zu, wobei zwei Funktionen und eine Klasse mit fünf Eigenschaften, eine Funktion und ein Konstruktor beteiligt sind. Das ist jede Menge Coding! Schlimmer noch, aufgrund der Delegation ist der Code vollkommen abstrakt und indirekt — es ist sehr schwierig, die Ausführung eines Codeteils und deren Auslöser nachzuverfolgen. Niemand, der mit diesem Modell gearbeitet hat, mag es besonders. Mit Parallel.For erreicht der Code nur bis zu 24 LOC und ist nicht besonders komplex aufgebaut:
Page: 1 2
Malware SmokeLoader wird weiterhin von Bedrohungsakteuren genutzt, um Payloads über neue C2-Infrastrukturen zu verbreiten.
Bankhaus Metzler und Telekom-Tochter MMS testen, inwieweit Bitcoin-Miner das deutsche Stromnetz stabilisieren könnten.
Mit 1,7 Exaflops ist El Capitan nun der dritte Exascale-Supercomputer weltweit. Deutschland stellt erneut den…
Der deutsche Hyperscaler erweitert sein Server-Portfolio um vier Angebote mit den neuen AMD EPYC 4004…
Beim Online-Gaming kommt es nicht nur auf das eigene Können an. Auch die technischen Voraussetzungen…
Fast jedes zweite Unternehmen bietet keinerlei Schulungen an. In den übrigen Betrieben profitieren oft nur…