Heim >Backend-Entwicklung >Python-Tutorial >Was sind Synchronisation, Asynchronität, Blockierung und Nichtblockierung in Python?

Was sind Synchronisation, Asynchronität, Blockierung und Nichtblockierung in Python?

王林
王林nach vorne
2023-04-24 09:37:071538Durchsuche

    1. Statuseinführung

    Bevor wir andere Konzepte verstehen, müssen wir zunächst mehrere Zustände des Prozesses verstehen. Während der Ausführung des Programms wechselt das Programm aufgrund der Steuerung des Planungsalgorithmus des Betriebssystems in verschiedene Zustände: bereit, läuft und blockiert.

    • Bereitschaftsstatus: Wenn dem Prozess alle erforderlichen Ressourcen außer der CPU zugewiesen wurden, kann er sofort ausgeführt werden, solange er den Prozessor erhält Der Zustand wird zu diesem Zeitpunkt als Bereitschaftszustand bezeichnet.

    • Ausführungs-/Laufstatus (Laufstatus) Wenn der Prozess den Prozessor erhalten hat und sein Programm auf dem Prozessor ausgeführt wird, wird der Prozessstatus zu diesem Zeitpunkt als Ausführung bezeichnet Zustand.

    • Ein Prozess, der im blockierten Zustand ausgeführt wird, gibt den Prozessor auf und befindet sich in einem blockierten Zustand, wenn er nicht ausgeführt werden kann, weil er auf das Eintreten eines Ereignisses wartet . Es kann viele Ereignisse geben, die zu einer Prozessblockierung führen, z. B. das Warten auf den Abschluss der E/A, die Nichtbefüllung des Anwendungspuffers, das Warten auf Buchstaben (Signale) usw.

    2. Synchronisation und Asynchronität

    Die sogenannte Asynchronität bedeutet, dass nicht auf den Abschluss der abhängigen Aufgabe gewartet werden muss, sondern Nur um die abhängige Aufgabe darüber zu informieren, was erledigt werden soll. Solange Sie die gesamte Aufgabe erledigen, wird sie ebenfalls sofort ausgeführt. Ob die abhängige Aufgabe am Ende tatsächlich abgeschlossen wird, kann nicht bestimmt werden, welche Aufgabe davon abhängt, sodass es sich um eine unzuverlässige Aufgabensequenz handelt.

    Beispiel

    • Der erste Weg: Wählen Sie, in der Schlange zu stehen;

    • #🎜🎜 # Die zweite Möglichkeit: Nimm ein kleines Stück Papier mit meiner Nummer darauf und wenn meine Nummer erreicht ist, teilt mir die Person am Schalter mit, dass ich an der Reihe bin, das Geschäft zu erledigen; 🎜#

      # 🎜🎜#Der erste Typ: Der erste Typ (in der Schlange stehen) besteht darin, gleichzeitig auf die Nachrichtenbenachrichtigung zu warten, das heißt, ich muss darauf warten, dass die Bank das Geschäft abwickelt; # Der zweite Typ: Letzterer (Warten auf Benachrichtigungen von anderen) ist asynchrones Warten auf Nachrichtenbenachrichtigungen. Bei der asynchronen Nachrichtenverarbeitung registriert die Person, die auf die Nachrichtenbenachrichtigung wartet (in diesem Fall die Person, die das Geschäft abwickelt), häufig einen Rückrufmechanismus Zähler) übergibt eine Art Rückrufmechanismus (in diesem Fall eine auf ein kleines Stück Papier geschriebene Zahl, sogenannte Nummer) und findet die Person, die auf das Ereignis wartet.

    • 3. Blockieren und Nichtblockieren

    Beispiel

    Fahren Sie mit dem obigen Beispiel fort, unabhängig davon, ob Sie in der Warteschlange stehen oder eine Nummer verwenden, um auf Benachrichtigung zu warten , wenn Sie hier warten Während des Prozesses kann der Kellner nichts anderes tun, als auf die Nachrichtenbenachrichtigung zu warten. Dann blockiert der Mechanismus, was sich im Programm widerspiegelt, dh das Programm wurde beim Funktionsaufruf blockiert und kann nicht fortgesetzt werden ausführen.

    Im Gegenteil, manche Leute telefonieren und verschicken gerne SMS, während sie diese Dienste in der Bank erledigen. Dieser Zustand ist nicht blockierend, weil er (der Kellner) dabei nicht blockiert ist Nachrichtenbenachrichtigung, aber warten Sie, während Sie Ihr eigenes Ding machen.

    Hinweis: Das synchrone, nicht blockierende Formular ist tatsächlich ineffizient. Stellen Sie sich vor, Sie müssen beim Telefonieren nachschauen, ob die Warteschlange Sie erreicht hat. Wenn das Tätigen eines Anrufs und das Beobachten der Warteschlangenposition als zwei Vorgänge des Programms betrachtet werden, muss das Programm zwischen diesen beiden unterschiedlichen Verhaltensweisen hin und her wechseln, was bei der asynchronen nicht blockierenden Form offensichtlich ineffizient ist. Es gibt kein solches Problem. Denn das Tätigen eines Anrufs ist Ihre Aufgabe (der Kellner) und die Benachrichtigung an Sie ist die Aufgabe des Schalters (Mechanismus zum Auslösen von Nachrichten) und das Programm wechselt nicht zwischen zwei verschiedenen Vorgängen hin und her.

    4. Synchron/asynchron und blockierend/nicht blockierend

    1. Asynchrones Blockierungsformular

    Wenn Leute darauf warten, Geschäfte bei der Bank abzuwickeln Warten Sie asynchron, bis die Nachricht ausgelöst wird (Benachrichtigung), dh erhalten Sie eine kleine Notiz. Wenn er die Bank in diesem Zeitraum nicht verlassen kann, um andere Dinge zu tun, ist es offensichtlich, dass diese Person in diesem Wartemodus blockiert ist.

    Asynchrone Vorgänge können blockiert werden, sie werden jedoch nicht während der Verarbeitung der Nachricht blockiert, sondern während des Wartens auf die Nachrichtenbenachrichtigung.

    2. Synchrones, nicht blockierendes Formular

    Stellen Sie sich vor, Sie telefonieren und müssen nachsehen, ob die Warteschlange Sie erreicht hat Beobachten der Warteschlange Wenn die Position als zwei Operationen des Programms betrachtet wird, muss das Programm zwischen diesen beiden unterschiedlichen Verhaltensweisen hin und her wechseln, was offensichtlich ineffizient ist.

    3. Asynchrones, nicht blockierendes Formular

    Denn das Anrufen ist Sache Ihres (Kellners) und das Benachrichtigen ist Sache des Schalters (Mechanismus zum Auslösen von Nachrichten) und Das Programm wechselt nicht zwischen zwei verschiedenen Vorgängen hin und her.

    Zum Beispiel merkt diese Person plötzlich, dass sie zigarettensüchtig ist und rauchen muss, also sagt sie dem Lobbymanager, dass er bitte nach draußen gehen und mich benachrichtigen soll, wenn seine Nummer erreicht ist. dann wird er in diesem Wartevorgang nicht blockiert, daher handelt es sich natürlich um eine asynchrone + nicht blockierende Methode.

    Das obige ist der detaillierte Inhalt vonWas sind Synchronisation, Asynchronität, Blockierung und Nichtblockierung in Python?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

    Stellungnahme:
    Dieser Artikel ist reproduziert unter:yisu.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen