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.
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;
# 🎜🎜#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.
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.
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.
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
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!