Ajax ist kein Multithread, sondern Single-Thread, da JavaScript Single-Thread ist und Ajax zur Kategorie von JavaScript gehört, sodass Ajax Single-Thread ist. Der Grund, warum Sie Ajax zum Erreichen von Multithreading verwenden können, hängt vom Webserver ab. Der Server verwendet Multithreading zur Verarbeitung von Anforderungen.
Die Betriebsumgebung dieses Tutorials: Windows 7-System, JavaScript-Version 1.8.5, Dell G3-Computer.
Ist Ajax Single-Threaded oder Multi-Threaded?
Lassen Sie uns zunächst klarstellen: Ajax ist Single-Threaded, weil JavaScript Single-Threaded ist und Ajax zur Kategorie von JavaScript gehört, also ist Ajax Single-Threaded. Der Grund, warum wir Ajax verwenden können, um Multithreading zu erreichen, hängt vom Webserver ab. Der Server verwendet Multithreading, um Anfragen zu verarbeiten.
Dann machen wir es klar: Der Browser ist multiprozessfähig. Wie in der Abbildung gezeigt, gibt es jedes Mal, wenn eine Registerkarte in Google Chrome geöffnet wird, einen untergeordneten Prozess.
Da JS im Browser ausgeführt wird, verfügt jedes Fenster über einen Single-Thread, sodass nur bestimmter Code zu einem bestimmten Zeitpunkt ausgeführt werden kann.
Ajax asynchron?
Ajax-Anfragen sind tatsächlich asynchron, da die JS-Engine aufgrund der Message Queue und der Event Loop einen neuen Thread öffnet. Viele Verhaltensweisen im Browser sind asynchron. Wenn ein asynchrones Ereignis auftritt, gelangt es in die Ereigniswarteschlange. Der Browser verfügt über eine interne große Nachrichtenschleife, die die große Ereigniswarteschlange abfragt und das Ereignis nur ausführt Nachdem die vorherige Verarbeitung abgeschlossen ist und das Ereignis inaktiv ist, führt die JavaScript-Engine die Rückruffunktion immer in einem einzelnen Thread aus.
Fazit:
Die Ajax-Anfrage ist tatsächlich asynchron. Diese Anfrage wird vom Browser gestellt, um eine neue Thread-Anfrage zu öffnen, und wird in die Single-Thread-Ereigniswarteschlange der Ereignisschleife gestellt zur Bearbeitung.
Die Rückruffunktion, die wir bei der Registrierung der asynchronen Aufgabe hinzugefügt haben, wird in die Nachrichtenwarteschlange gestellt. Nachdem der Hauptthread die AJAX-Anfrage initiiert hat, führt er weiterhin anderen Code aus. Der AJAX-Thread ist für die Anforderung der URL verantwortlich. Nachdem er die Antwort erhalten hat, kapselt er die Antwort in ein JavaScript-Objekt und erstellt dann eine Nachricht:
// ajax请求 $.ajax(url, function(resp) { console.log('我是响应:', resp); }); // 消息队列中的消息就长这个样子 var message = function () { callbackFn(response); } // 其中的callbackFn就是前面代码中得到成功响应时的回调函数。
Nachdem der Hauptthread die Ausführung des gesamten Codes in der aktuellen Schleife abgeschlossen hat, wird er ausgeführt in die Nachrichtenwarteschlange, um diese Nachricht abzurufen und auszuführen. Bisher wurde die Benachrichtigung des Arbeitsthreads an den Hauptthread abgeschlossen und die Rückruffunktion ausgeführt. Wenn der Hauptthread zu Beginn keine Rückruffunktion bereitstellt, muss der AJAX-Thread den Hauptthread nach Erhalt der HTTP-Antwort nicht benachrichtigen, und es besteht keine Notwendigkeit, Nachrichten in die Nachrichtenwarteschlange zu stellen. Unter anderem darf die Rückruffunktion des asynchronen Prozesses in der aktuellen Runde der Ereignisschleife nicht ausgeführt werden.
【Ähnliche Tutorial-Empfehlung: AJAX-Video-Tutorial】
Das obige ist der detaillierte Inhalt vonIst Ajax Multi-Threaded?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!