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
Bisher unbekannter Bedrohungsakteur versucht über gefälschte IP Scanner Software-Domänen Zugriff auf IT-Umgebungen zu erlangen.
Der Bericht zeigt bereits nutzbare Angriffsanwendungen und bewertet die Risiken, die davon ausgehen.
Deutsche sehen Finanzwesen und IT im Zentrum der KI-Transformation. Justiz und Militär hingegen werden deutlich…
Cubbit ist das weltweit erste Unternehmen, das Cloud-Objektspeicher anbietet. Es wurde 2016 gegründet und bedient…
Unbefugte können Schadcode einschleusen und ausführen. Auslöser ist eine fehlerhafte Implementierung einer Android-Funktion.
iPhones und iPads belasten das Ergebnis. Außerdem schwächelt Apple im gesamten asiatischen Raum inklusive China…