Rheinwerk Computing < openbook >

 
Inhaltsverzeichnis
1 Einleitung
2 Die Programmiersprache Python
Teil I Einstieg in Python
3 Erste Schritte im interaktiven Modus
4 Der Weg zum ersten Programm
5 Kontrollstrukturen
6 Dateien
7 Das Laufzeitmodell
8 Funktionen, Methoden und Attribute
9 Informationsquellen zu Python
Teil II Datentypen
10 Das Nichts – NoneType
11 Operatoren
12 Numerische Datentypen
13 Sequenzielle Datentypen
14 Zuordnungen
15 Mengen
16 Collections
17 Datum und Zeit
18 Aufzählungstypen – Enum
Teil III Fortgeschrittene Programmiertechniken
19 Funktionen
20 Modularisierung
21 Objektorientierung
22 Ausnahmebehandlung
23 Iteratoren
24 Kontextobjekte
25 Manipulation von Funktionen und Methoden
Teil IV Die Standardbibliothek
26 Mathematik
27 Kryptografie
28 Reguläre Ausdrücke
29 Schnittstelle zu Betriebssystem und Laufzeitumgebung
30 Kommandozeilenparameter
31 Dateisystem
32 Parallele Programmierung
33 Datenspeicherung
34 Netzwerkkommunikation
35 Debugging und Qualitätssicherung
36 Dokumentation
Teil V Weiterführende Themen
37 Anbindung an andere Programmiersprachen
38 Distribution von Python-Projekten
39 Grafische Benutzeroberflächen
40 Python als serverseitige Programmiersprache im WWW – ein Einstieg in Django
41 Wissenschaftliches Rechnen
42 Insiderwissen
43 Von Python 2 nach Python 3
A Anhang
Stichwortverzeichnis

Download:
- Beispielprogramme, ca. 464 KB

Jetzt Buch bestellen
Ihre Meinung?

Spacer
<< zurück
Python 3 von Johannes Ernesti, Peter Kaiser
Das umfassende Handbuch
Buch: Python 3

Python 3
Pfeil 32 Parallele Programmierung
Pfeil 32.1 Prozesse, Multitasking und Threads
Pfeil 32.1.1 Die Leichtgewichte unter den Prozessen – Threads
Pfeil 32.1.2 Threads oder Prozesse?
Pfeil 32.2 Pythons Schnittstellen zur Parallelisierung
Pfeil 32.3 Parallelisierung von Funktionsaufrufen
Pfeil 32.3.1 Ein Beispiel mit einem futures.ThreadPoolExecutor
Pfeil 32.3.2 Executor-Instanzen als Kontext-Manager
Pfeil 32.3.3 Die Verwendung von futures.ProcessPoolExecutor
Pfeil 32.3.4 Die Verwaltung der Aufgaben eines Executors
Pfeil 32.4 Die Module threading und multiprocessing
Pfeil 32.5 Die Thread-Unterstützung in Python
Pfeil 32.5.1 Kritische Bereiche mit Lock-Objekten absichern
Pfeil 32.5.2 Datenaustausch zwischen Threads mit Critical Sections
Pfeil 32.5.3 Gefahren von Critical Sections – Deadlocks
Pfeil 32.6 Einblick in das Modul multiprocessing
Pfeil 32.7 Ausblick
 
Zum Seitenanfang

32.2    Pythons Schnittstellen zur Parallelisierung Zur vorigen ÜberschriftZur nächsten Überschrift

Python stellt verschiedene Schnittstellen bereit, um Teile eines Programms in verschiedenen Threads oder Prozessen auszuführen. Dabei hängt es von dem konkreten Einsatzzweck ab, welche der Schnittstellen verwendet werden sollte.

Schnittstelle Eigenschaften
concurrent.futures hoher Abstraktionsgrad, geringe Flexibilität, keine Möglichkeiten zur Synchronisierung
threading, multiprocessing geringerer Abstraktionsgrad, hohe Flexibilität, Synchronisierungsmöglichkeiten

Tabelle 32.1    Pythons Schnittstellen zur Parallelisierung

Für einfache Aufgaben, die unabhängig voneinander und ohne Datenaustausch durchgeführt werden können, gibt es das Modul concurrent.futures[ 129 ](Das Modul concurrent.futures wurde in Python 3.2 eingeführt. Mit dem Modul futures im Python Package Index kann diese Funktion aber auch in älteren Versionen von Python genutzt werden. ). Es stellt eine komfortable Schnittstelle zur Verfügung, die es ermöglicht, Funktionsaufrufe in verschiedenen Threads oder Prozessen auszuführen. Dabei wird davon ausgegangen, dass jeder Funktionsaufruf unabhängig von den anderen durchlaufen werden kann, wobei die Reihenfolge der Aufrufe keine Rolle spielen darf und auch keine Daten zwischen den verschiedenen Funktionsaufrufen ausgetauscht werden dürfen.

Die Module threading und multiprocessing hingegen stellen mächtige Werkzeuge bereit, um bei parallelen Programmen auch Daten zwischen Prozessen beziehungsweise Threads in sicherer Weise auszutauschen. Intern verwendet concurrent.futures die Fähigkeiten der Module threading beziehungsweise multiprocessing, sodass es sich dabei nicht um eine gesonderte Implementierung, sondern eine zusätzliche Abstraktionsschicht handelt.

Wir werden in diesem Kapitel zunächst die abstraktere Schnittstelle concurrent.futures betrachten und später auf ausgewählte Probleme der Synchronisierung mehrerer Threads oder Prozesse in threading und multiprocessing eingehen.

 


Ihre Meinung

Wie hat Ihnen das Openbook gefallen? Wir freuen uns immer über Ihre Rückmeldung. Schreiben Sie uns gerne Ihr Feedback als E-Mail an kommunikation@rheinwerk-verlag.de.

<< zurück
 Zum Rheinwerk-Shop
Zum Rheinwerk-Shop: Python 3 Python 3
Jetzt Buch bestellen

 Buchempfehlungen
Zum Rheinwerk-Shop: Einstieg in Python
Einstieg in Python


Zum Rheinwerk-Shop: Python. Der Grundkurs
Python. Der Grundkurs


Zum Rheinwerk-Shop: Algorithmen mit Python
Algorithmen mit Python


Zum Rheinwerk-Shop: Objektorientierte Programmierung
Objektorientierte Programmierung


Zum Rheinwerk-Shop: Raspberry Pi. Das umfassende Handbuch
Raspberry Pi. Das umfassende Handbuch


Zum Rheinwerk-Shop: Roboter-Autos mit dem Raspberry Pi
Roboter-Autos mit dem Raspberry Pi


Zum Rheinwerk-Shop: Neuronale Netze programmieren mit Python
Neuronale Netze programmieren mit Python


 Lieferung
Versandkostenfrei bestellen in Deutschland, Österreich und der Schweiz
InfoInfo

 
 


Copyright © Rheinwerk Verlag GmbH 2020
Für Ihren privaten Gebrauch dürfen Sie die Online-Version natürlich ausdrucken. Ansonsten unterliegt das Openbook denselben Bestimmungen, wie die gebundene Ausgabe: Das Werk einschließlich aller seiner Teile ist urheberrechtlich geschützt.
Alle Rechte vorbehalten einschließlich der Vervielfältigung, Übersetzung, Mikroverfilmung sowie Einspeicherung und Verarbeitung in elektronischen Systemen.

 
[Rheinwerk Computing]

Rheinwerk Verlag GmbH, Rheinwerkallee 4, 53227 Bonn, Tel.: 0228.42150.0, Fax 0228.42150.77, service@rheinwerk-verlag.de

Cookie-Einstellungen ändern