這篇文章主要為大家展示了“ajax是不是多線程”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習一下“ajax是不是多線程”這篇文章吧。
公司主營業(yè)務(wù):做網(wǎng)站、成都網(wǎng)站建設(shè)、移動網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出利州免費做網(wǎng)站回饋大家。
ajax不是多線程,而是單線程的,因為JavaScript是單線程的,而Ajax屬于JavaScript范疇,因此Ajax是單線程的。之所以可以利用Ajax做到多線程,這取決于Web服務(wù)器,服務(wù)端使用多線程處理請求。
本教程操作環(huán)境:windows7系統(tǒng)、javascript1.8.5版、Dell G3電腦。
Ajax是單線程還是多線程?
首先明確一點:Ajax是單線程的,因為JavaScript是單線程的,Ajax屬于JavaScript范疇,因此Ajax是單線程的。之所以我們可以利用Ajax做到多線程,這取決于Web服務(wù)器,服務(wù)端使用多線程處理請求。
然后再明確一點:瀏覽器是多進程的。如圖,google瀏覽器每打開一個tab標簽頁就會有一個子進程。
因為JS運行在瀏覽器中,是單線程的,每個window一個JS線程,既然是單線程的,在某個特定的時刻只有特定的代碼能夠被執(zhí)行,并阻塞其它的代碼。
Ajax異步?
Ajax請求確實是異步的,js引擎執(zhí)行異步代碼而不用等待,是因有為有 消息隊列和事件循環(huán),這請求是由瀏覽器新開一個線程請求。瀏覽器中很多行為是異步的,當一個異步事件發(fā)生的時候,它就進入事件隊列,瀏覽器有一個內(nèi)部大消息循環(huán),Event Loop(事件循環(huán)),會輪詢大的事件隊列并處理事件,只有前面的處理完畢了,空閑了才會執(zhí)行這個事件,而JavaScript引擎始終是單線程運行回調(diào)函數(shù)。
結(jié)論:
Ajax請求確實是異步的,這請求是由瀏覽器新開一個線程請求,事件回調(diào)的時候是放入Event loop單線程事件隊列等候處理。
消息隊列中放著我們注冊異步任務(wù)時添加的回調(diào)函數(shù),主線程在發(fā)起AJAX請求后,會繼續(xù)執(zhí)行其他代碼。AJAX線程負責請求url,拿到響應(yīng)后,它會把響應(yīng)封裝成一個JavaScript對象,然后構(gòu)造一條消息:
// ajax請求 $.ajax(url, function(resp) { console.log('我是響應(yīng):', resp); }); // 消息隊列中的消息就長這個樣子 var message = function () { callbackFn(response); } // 其中的callbackFn就是前面代碼中得到成功響應(yīng)時的回調(diào)函數(shù)。
主線程在執(zhí)行完當前循環(huán)中的所有代碼后,就會到消息隊列取出這條消息并執(zhí)行它,到此為止,就完成了工作線程對主線程的通知,回調(diào)函數(shù)也就得到了執(zhí)行。如果一開始主線程就沒有提供回調(diào)函數(shù),AJAX線程在收到HTTP響應(yīng)后,也就沒必要通知主線程,從而也沒必要往消息隊列放消息。其中,異步過程的回調(diào)函數(shù),一定不在當前這一輪事件循環(huán)中執(zhí)行。
以上是“ajax是不是多線程”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!