Nodejs ist kein Multithread-, sondern ein Single-Thread-Modus. Aufgrund der JavaScript-Engine kann eine Nodejs-Anwendung keine Multi-Core-Ressourcen nutzen können ereignisgesteuerte und asynchrone „I/O“-Methoden sein, um eine Single-Threaded-Laufzeitumgebung mit hoher Parallelität zu erreichen.
Die Betriebsumgebung dieses Artikels: Windows 10-System, NodeJS-Version 12.19.0, Dell G3-Computer.
node ist Single-Threaded und verwendet den asynchronen, nicht blockierenden Single-Threaded-Modus.
Aufgrund der JavaScript-Engine ist der Knoten standardmäßig Single-Threaded und eine node.js-Anwendung kann keine Multi-Core-Ressourcen nutzen.
Node.js verwendet ereignisgesteuerte und asynchrone E/A, um eine Single-Threaded-Laufzeitumgebung mit hoher Parallelität zu implementieren, und Single-Threading bedeutet, dass nur eine Sache gleichzeitig erledigt werden kann.
nodejs implementiert asynchrone, nicht blockierende Funktion:
nodejs verfügt tatsächlich nur über eine Single-Threaded-JS-Ausführung, und E/A erfolgt offensichtlich über andere Threads.
Der js-Ausführungsthread ist Single-Threaded. Übergeben Sie einfach die erforderliche E/A an libuv, kehren Sie sofort zurück, um andere Dinge zu erledigen, und ruft dann zur angegebenen Zeit zurück.
Im Detail wird nodejs zunächst vom js-Code in Knotenbindungen zum C/C-Code aufgerufen und dann etwas namens „Anforderungsobjekt“ im C/C-Code gekapselt und an libuv übergeben. Einige dieser Anforderungsobjekte ähneln Funktionsrückrufen, die ausgeführt werden müssen. Führen Sie einfach den Rückruf an libuv aus und implementieren Sie den Rückruf nach der Ausführung.
Kurz gesagt ist der allgemeine Prozess der asynchronen E/A wie folgt.
1. Starten Sie den I/O-Aufruf
Der Benutzer ruft das Node-Kernmodul aus dem Javascript-Code auf und übergibt die Parameter und die Rückruffunktion an das Kernmodul.
Das Node-Kernmodul kapselt die übergebenen Parameter und die Rückruffunktion in der Anfrage Objekt.
Schieben Sie dieses Anforderungsobjekt an den E/A-Thread-Pool, um auf die Ausführung zu warten.
Der asynchrone Javascript-Aufruf wird beendet und der Javascript-Thread führt weiterhin nachfolgende Vorgänge aus.
2. Rückruf ausführen
Nachdem der E/A-Vorgang abgeschlossen ist, wird die zuvor im Anforderungsobjekt gekapselte Rückruffunktion abgerufen und ausgeführt, um den Zweck des Javascript-Rückrufs zu erreichen. (Die Details des Rückrufs hier werden unten erläutert)
Hier ist ersichtlich, dass wir den einzelnen Thread von Node.js tatsächlich falsch verstanden haben.
Tatsächlich bezieht sich „Einzelthread“ auf einen einzelnen Thread in der Javascript-Laufzeitumgebung. Node.js verfügt nicht über die Möglichkeit, beim Ausführen von Javascript neue Threads zu erstellen. Die letzten tatsächlichen Operationen werden weiterhin in Libuv und seiner Ereignisschleife ausgeführt. Aus diesem Grund kann Javascript, eine Single-Threaded-Sprache, asynchrone Vorgänge in Node.js implementieren. Die beiden werden nicht in Konflikt geraten.
Erweiterte Kenntnisse:
Node.js Multi-Threading-Übersicht
Einige Leute sagen vielleicht, dass Node.js zwar Single-Threaded ist, aber zyklische Ereignisse (Ereignisschleife) verwenden kann, um gleichzeitige Ausführungsaufgaben zu implementieren. Bei der Untersuchung seines Wesens verwendet NodeJs tatsächlich zwei verschiedene Threads, einer ist der Hauptthread für die Verarbeitung von Schleifenereignissen und der andere sind einige Hilfsthreads im Worker-Pool. Die Hauptfunktionen und Beziehungen dieser beiden Threads sind in der Abbildung dargestellt
Empfohlenes Lernen: „nodejs-Video-Tutorial“
Das obige ist der detaillierte Inhalt vonIst NodeJS Multithread-fähig?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!