Parallelität in Python

Parallelität wird oft als Parallelität missverstanden. Parallelität bedeutet, dass unabhängiger Code so geplant wird, dass er systematisch ausgeführt wird. Dieses Kapitel konzentriert sich auf die Ausführung der Parallelität für ein Betriebssystem mit Python.

Das folgende Programm hilft bei der Ausführung der Parallelität für ein Betriebssystem -

import os
import time
import threading
import multiprocessing

NUM_WORKERS = 4

def only_sleep():
   print("PID: %s, Process Name: %s, Thread Name: %s" % (
      os.getpid(),
      multiprocessing.current_process().name,
      threading.current_thread().name)
   )
   time.sleep(1)

def crunch_numbers():
   print("PID: %s, Process Name: %s, Thread Name: %s" % (
      os.getpid(),
      multiprocessing.current_process().name,
      threading.current_thread().name)
   )
   x = 0
   while x < 10000000:
      x += 1
for _ in range(NUM_WORKERS):
   only_sleep()
end_time = time.time()
print("Serial time=", end_time - start_time)

# Run tasks using threads
start_time = time.time()
threads = [threading.Thread(target=only_sleep) for _ in range(NUM_WORKERS)]
[thread.start() for thread in threads]
[thread.join() for thread in threads]
end_time = time.time()

print("Threads time=", end_time - start_time)

# Run tasks using processes
start_time = time.time()
processes = [multiprocessing.Process(target=only_sleep()) for _ in range(NUM_WORKERS)]
[process.start() for process in processes]
[process.join() for process in processes]
end_time = time.time()

print("Parallel time=", end_time - start_time)

Ausgabe

Das obige Programm erzeugt die folgende Ausgabe -

Erläuterung

"Multiprocessing" ist ein Paket ähnlich dem Threading-Modul. Dieses Paket unterstützt lokale und Remote-Parallelität. Durch dieses Modul erhalten Programmierer den Vorteil, mehrere Prozesse auf dem jeweiligen System zu verwenden.