Heim Backend-Entwicklung Python-Tutorial Eine Einführung in Multithreading in Python

Eine Einführung in Multithreading in Python

Aug 23, 2017 am 11:44 AM
python threading 入门

Multithreading kann einfach als die gleichzeitige Ausführung mehrerer Aufgaben verstanden werden. In diesem Artikel werden detaillierte Beispiele für Python-Multithreading-Threading-Anfänger-Tutorials vorgestellt. Interessierte Freunde können gemeinsam lernen

1.1 Was ist Multithreading

Unter Multithreading kann einfach das gleichzeitige Ausführen mehrerer Aufgaben verstanden werden.

Sowohl Multiprozess als auch Multithreading können mehrere Aufgaben ausführen, und Threads sind Teil des Prozesses. Das Merkmal von Threads besteht darin, dass sie Speicher und Variablen zwischen Threads gemeinsam nutzen können und weniger Ressourcen verbrauchen (in der Unix-Umgebung ist der Unterschied im Ressourcenplanungsverbrauch zwischen Multiprozess und Multithread jedoch nicht offensichtlich, und die Unix-Planung ist schneller ). Der Nachteil ist, dass die Synchronisierung und Beschleunigung zwischen Threads problematischer ist.

1.2 Thread-Thread hinzufügen

Modul importieren


import threading
Nach dem Login kopieren

Erhaltene Nummer der aktivierten Threads


threading.active_count()
Nach dem Login kopieren

Alle Threadinformationen anzeigen


threading.enumerate()
Nach dem Login kopieren

Die derzeit laufenden Threads anzeigen


threading.current_thread()
Nach dem Login kopieren

Fügen Sie einen Thread hinzu, threading.Thread()erhält den Parameter target, um die von diesem Thread auszuführende Aufgabe darzustellen. Sie müssen ihn selbst definieren


def thread_job():
  print('This is a thread of %s' % threading.current_thread())
def main():
  thread = threading.Thread(target=thread_job,)  # 定义线程 
  thread.start() # 让线程开始工作
  if __name__ == '__main__':
  main()
Nach dem Login kopieren

1.3 Join-Funktion

Da die Threads gleichzeitig ausgeführt werden, ermöglicht die Verwendung der Join-Funktion den Thread um den nächsten Schritt abzuschließen, bevor mit dem nächsten Vorgang fortgefahren wird, d. h. dem Blockieren. Der aufrufende Thread wartet, bis alle Aufgaben in der Warteschlange verarbeitet wurden.


import threading
import time
def thread_job():
  print('T1 start\n')
  for i in range(10):
    time.sleep(0.1)
  print('T1 finish\n')
def T2_job():
  print('T2 start\n')
  print('T2 finish\n')
def main():
  added_thread=threading.Thread(target=thread_job,name='T1')
  thread2=threading.Thread(target=T2_job,name='T2')
  added_thread.start()
  #added_thread.join()
  thread2.start()
  #thread2.join()
  print('all done\n')
if __name__=='__main__':
   main()
Nach dem Login kopieren

Das Beispiel ist oben dargestellt. Wenn die Join-Funktion nicht verwendet wird, ist das Ergebnis wie folgt:

Wenn die Join-Funktion ausgeführt wird, wird T2 erst ausgeführt, nachdem T1 die Ausführung beendet hat, und dann wird print ausgeführt („alles erledigt“)

1.4 Warteschlange zum Speichern von Prozessergebnissen

Warteschlange ist eine Thread-sichere Warteschlangen-Implementierung (FIFO) in der Python-Standardbibliothek, die ein First-in- First-Out-Methode, geeignet für Multithread-Programmierung. Datenstrukturen, nämlich Warteschlangen, werden zum Übertragen von Informationen zwischen Produzenten- und Konsumenten-Threads verwendet

(1) Grundlegende FIFO-Warteschlange


 class queue.Queue(maxsize=0)
Nach dem Login kopieren

maxsize ist eine Ganzzahl, die die Obergrenze der Anzahl der Daten angibt, die in der Warteschlange gespeichert werden können. Wenn die Obergrenze erreicht ist, führt das Einfügen zu einer Blockierung, bis die Daten in der Warteschlange verbraucht sind kleiner oder gleich 0 ist, gibt es keine Begrenzung für die Warteschlangengröße

(2) LIFO-Warteschlange Last In First Out


class queue.LifoQueue(maxsize=0)
Nach dem Login kopieren

( 3) Prioritätswarteschlange


class queue.PriorityQueue(maxsize=0)
Nach dem Login kopieren

Der Code im Video ist nicht sehr klar


import threading
import time
from queue import Queue
def job(l,q):
  for i in range(len(l)):
    l[i]=l[i]**2
  q.put(l)
def multithreading():
  q=Queue()
  threads=[]
  data=[[1,2,3],[3,4,5],[4,5,6],[5,6,7]]
  for i in range(4):
    t=threading.Thread(target=job,args=(data[i],q))
    t.start()
    threads.append(t)
  for thread in threads:
    thread.join()
  results=[]
  for _ in range(4):
    results.append(q.get())
  print(results)
if __name__=='__main__':
   multithreading()
Nach dem Login kopieren

Der Das laufende Ergebnis ist wie folgt

1.5 GIL ist möglicherweise nicht effizient

Global Interpreter Lock, Python ist Durch die von der virtuellen Python-Maschine ausgeführte Steuerung (auch als Interpreter-Hauptschleife bezeichnet) steuert GIL den Zugriff auf die virtuelle Python-Maschine und stellt sicher, dass immer nur ein Thread im Interpreter ausgeführt wird. In einer Multithread-Umgebung wird die virtuelle Python-Maschine wie folgt ausgeführt:

1. GIL festlegen

2 :

a. Geben Sie die Anzahl der Bytecode-Anweisungen an, oder

b Der Thread gibt die Kontrolle aktiv auf (time.sleep(0) kann aufgerufen werden)

4. Legen Sie den Thread für den Ruhezustand fest

5. GIL entsperren

6. Wiederholen Sie 1-5

Beim Aufrufen von externem Code (z. B. C/C++-Erweiterungsfunktionen) wird die GIL wird bis zum Ende dieser Funktion gesperrt (da in diesem Zeitraum kein Python-Bytecode ausgeführt wird, wird kein Threadwechsel durchgeführt).

Das Folgende ist das Codebeispiel im Video. Es erweitert eine Zahl um das Vierfache, teilt sie in die normale Methode auf und weist sie 4 Threads zu.


Das laufende Ergebnis ist:
import threading
from queue import Queue
import copy
import time
def job(l, q):
  res = sum(l)
  q.put(res)
def multithreading(l):
  q = Queue()
  threads = []
  for i in range(4):
    t = threading.Thread(target=job, args=(copy.copy(l), q), name='T%i' % i)
    t.start()
    threads.append(t)
  [t.join() for t in threads]
  total = 0
  for _ in range(4):
    total += q.get()
  print(total)
def normal(l):
  total = sum(l)
  print(total)
if __name__ == '__main__':
  l = list(range(1000000))
  s_t = time.time()
  normal(l*4)
  print('normal: ',time.time()-s_t)
  s_t = time.time()
  multithreading(l)
  print('multithreading: ', time.time()-s_t)
Nach dem Login kopieren

1.6 线程锁 Lock

如果线程1得到了结果,想要让线程2继续使用1的结果进行处理,则需要对1lock,等到1执行完,再开始执行线程2。一般来说对share memory即对共享内存进行加工处理时会用到lock。


import threading
def job1():
  global A, lock #全局变量
  lock.acquire() #开始lock
  for i in range(10):
    A += 1
    print('job1', A)
  lock.release() #释放
def job2(): 
  global A, lock
  lock.acquire()
  for i in range(10):
    A += 10
    print('job2', A)
  lock.release()
if __name__ == '__main__':
  lock = threading.Lock()
  A = 0
  t1 = threading.Thread(target=job1)
  t2 = threading.Thread(target=job2)
  t1.start()
  t2.start()
  t1.join()
  t2.join()
Nach dem Login kopieren

运行结果如下所示:

总结

Das obige ist der detaillierte Inhalt vonEine Einführung in Multithreading in Python. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

PHP und Python: Code Beispiele und Vergleich PHP und Python: Code Beispiele und Vergleich Apr 15, 2025 am 12:07 AM

PHP und Python haben ihre eigenen Vor- und Nachteile, und die Wahl hängt von den Projektbedürfnissen und persönlichen Vorlieben ab. 1.PHP eignet sich für eine schnelle Entwicklung und Wartung großer Webanwendungen. 2. Python dominiert das Gebiet der Datenwissenschaft und des maschinellen Lernens.

Python gegen JavaScript: Community, Bibliotheken und Ressourcen Python gegen JavaScript: Community, Bibliotheken und Ressourcen Apr 15, 2025 am 12:16 AM

Python und JavaScript haben ihre eigenen Vor- und Nachteile in Bezug auf Gemeinschaft, Bibliotheken und Ressourcen. 1) Die Python-Community ist freundlich und für Anfänger geeignet, aber die Front-End-Entwicklungsressourcen sind nicht so reich wie JavaScript. 2) Python ist leistungsstark in Bibliotheken für Datenwissenschaft und maschinelles Lernen, während JavaScript in Bibliotheken und Front-End-Entwicklungsbibliotheken und Frameworks besser ist. 3) Beide haben reichhaltige Lernressourcen, aber Python eignet sich zum Beginn der offiziellen Dokumente, während JavaScript mit Mdnwebdocs besser ist. Die Wahl sollte auf Projektbedürfnissen und persönlichen Interessen beruhen.

Detaillierte Erklärung des Docker -Prinzips Detaillierte Erklärung des Docker -Prinzips Apr 14, 2025 pm 11:57 PM

Docker verwendet Linux -Kernel -Funktionen, um eine effiziente und isolierte Anwendungsumgebung zu bieten. Sein Arbeitsprinzip lautet wie folgt: 1. Der Spiegel wird als schreibgeschützte Vorlage verwendet, die alles enthält, was Sie für die Ausführung der Anwendung benötigen. 2. Das Union File System (UnionFS) stapelt mehrere Dateisysteme, speichert nur die Unterschiede, speichert Platz und beschleunigt. 3. Der Daemon verwaltet die Spiegel und Container, und der Kunde verwendet sie für die Interaktion. 4. Namespaces und CGroups implementieren Container -Isolation und Ressourcenbeschränkungen; 5. Mehrere Netzwerkmodi unterstützen die Containerverbindung. Nur wenn Sie diese Kernkonzepte verstehen, können Sie Docker besser nutzen.

So führen Sie Programme in der terminalen VSCODE aus So führen Sie Programme in der terminalen VSCODE aus Apr 15, 2025 pm 06:42 PM

Im VS -Code können Sie das Programm im Terminal in den folgenden Schritten ausführen: Erstellen Sie den Code und öffnen Sie das integrierte Terminal, um sicherzustellen, dass das Codeverzeichnis mit dem Terminal Working -Verzeichnis übereinstimmt. Wählen Sie den Befehl aus, den Befehl ausführen, gemäß der Programmiersprache (z. B. Pythons Python your_file_name.py), um zu überprüfen, ob er erfolgreich ausgeführt wird, und Fehler auflösen. Verwenden Sie den Debugger, um die Debugging -Effizienz zu verbessern.

Python: Automatisierung, Skript- und Aufgabenverwaltung Python: Automatisierung, Skript- und Aufgabenverwaltung Apr 16, 2025 am 12:14 AM

Python zeichnet sich in Automatisierung, Skript und Aufgabenverwaltung aus. 1) Automatisierung: Die Sicherungssicherung wird durch Standardbibliotheken wie OS und Shutil realisiert. 2) Skriptschreiben: Verwenden Sie die PSUTIL -Bibliothek, um die Systemressourcen zu überwachen. 3) Aufgabenverwaltung: Verwenden Sie die Zeitplanbibliothek, um Aufgaben zu planen. Die Benutzerfreundlichkeit von Python und die Unterstützung der reichhaltigen Bibliothek machen es zum bevorzugten Werkzeug in diesen Bereichen.

Ist die VSCODE -Erweiterung bösartig? Ist die VSCODE -Erweiterung bösartig? Apr 15, 2025 pm 07:57 PM

VS -Code -Erweiterungen stellen böswillige Risiken dar, wie das Verstecken von böswilligem Code, das Ausbeutetieren von Schwachstellen und das Masturbieren als legitime Erweiterungen. Zu den Methoden zur Identifizierung böswilliger Erweiterungen gehören: Überprüfung von Verlegern, Lesen von Kommentaren, Überprüfung von Code und Installation mit Vorsicht. Zu den Sicherheitsmaßnahmen gehören auch: Sicherheitsbewusstsein, gute Gewohnheiten, regelmäßige Updates und Antivirensoftware.

Wofür ist VSCODE Wofür ist VSCODE? Wofür ist VSCODE Wofür ist VSCODE? Apr 15, 2025 pm 06:45 PM

VS Code ist der vollständige Name Visual Studio Code, der eine kostenlose und open-Source-plattformübergreifende Code-Editor und Entwicklungsumgebung von Microsoft ist. Es unterstützt eine breite Palette von Programmiersprachen und bietet Syntax -Hervorhebung, automatische Codebettel, Code -Snippets und intelligente Eingabeaufforderungen zur Verbesserung der Entwicklungseffizienz. Durch ein reiches Erweiterungs -Ökosystem können Benutzer bestimmte Bedürfnisse und Sprachen wie Debugger, Code -Formatierungs -Tools und Git -Integrationen erweitern. VS -Code enthält auch einen intuitiven Debugger, mit dem Fehler in Ihrem Code schnell gefunden und behoben werden können.

So installieren Sie Nginx in CentOS So installieren Sie Nginx in CentOS Apr 14, 2025 pm 08:06 PM

Die Installation von CentOS-Installationen erfordert die folgenden Schritte: Installieren von Abhängigkeiten wie Entwicklungstools, PCRE-Devel und OpenSSL-Devel. Laden Sie das Nginx -Quellcode -Paket herunter, entpacken Sie es, kompilieren Sie es und installieren Sie es und geben Sie den Installationspfad als/usr/local/nginx an. Erstellen Sie NGINX -Benutzer und Benutzergruppen und setzen Sie Berechtigungen. Ändern Sie die Konfigurationsdatei nginx.conf und konfigurieren Sie den Hörport und den Domänennamen/die IP -Adresse. Starten Sie den Nginx -Dienst. Häufige Fehler müssen beachtet werden, z. B. Abhängigkeitsprobleme, Portkonflikte und Konfigurationsdateifehler. Die Leistungsoptimierung muss entsprechend der spezifischen Situation angepasst werden, z. B. das Einschalten des Cache und die Anpassung der Anzahl der Arbeitsprozesse.

See all articles