html5 - Javascript單線程中消息隊(duì)列的執(zhí)行疑問
問題描述
陸陸續(xù)續(xù)看了一些js單線程,事件循環(huán)和消息隊(duì)列的文章,但是有一個(gè)疑問是,當(dāng)event loop消息隊(duì)列的時(shí)候,假設(shè)里面有ajax和settimeout兩個(gè)消息,當(dāng)?shù)莝ettimeout是先進(jìn)入消息隊(duì)列,ajax是后入,但是ajax先回饋結(jié)果了,settimout還沒有,這個(gè)時(shí)候,event loop應(yīng)該是先執(zhí)行ajax吧?其實(shí)結(jié)合日常開發(fā)我也知道應(yīng)該是這么回事,但是我看一些文章好像說異步消息隊(duì)列也是按順序輪詢執(zhí)行的,但是明明后面的比你先反饋,應(yīng)該是先執(zhí)行對把?
問題解答
回答1:ajax執(zhí)行完,剩余事件進(jìn)入 event loop. setTimeout 在延遲的時(shí)間結(jié)束時(shí),將參數(shù)里的回掉放入event loop。
推薦你一個(gè)網(wǎng)站,在線掩飾event loophttp://latentflip.com/loupe
回答2:這個(gè)問題, 說起來比較長, 這里有篇文章, 很長但是建議深讀. Ajax知識體系大梳理 | louis blog當(dāng)然sf的專欄也是有的: Ajax知識體系大梳理 - 路易斯聊前端如果有不明白的地方, 直接文章底下給我留言就行.
回答3:按照我這兩天看的情況,異步任務(wù)只有在完成相關(guān)觸發(fā)條件才會被推入“任務(wù)隊(duì)列”,等待主線程執(zhí)行完同步任務(wù)按照先進(jìn)先出的順序執(zhí)行“任務(wù)隊(duì)列”中的任務(wù)。
相關(guān)文章:
1. 我在centos容器里安裝docker,也就是在容器里安裝容器,報(bào)錯(cuò)了?2. 在windows下安裝docker Toolbox 啟動(dòng)Docker Quickstart Terminal 失敗!3. docker-compose中volumes的問題4. docker不顯示端口映射呢?5. golang - 用IDE看docker源碼時(shí)的小問題6. docker內(nèi)創(chuàng)建jenkins訪問另一個(gè)容器下的服務(wù)器問題7. 關(guān)docker hub上有些鏡像的tag被標(biāo)記““This image has vulnerabilities””8. javascript - 最近用echarts做統(tǒng)計(jì)圖時(shí)遇到兩個(gè)問題!!9. javascript - 連續(xù)點(diǎn)擊觸發(fā)mouseleave事件10. mac里的docker如何命令行開啟呢?

網(wǎng)公網(wǎng)安備