本篇文章帶大家了解一下Node.js異步編程中的事件循環(huán)。事件循環(huán)是實(shí)現(xiàn)Node非阻塞I/O非常重要的一部分!事件循環(huán),非阻塞I/O都是屬于LIBUV這個(gè)C++庫的底層能力。理解了事件循環(huán),非阻塞I/O就理解了Node的異步是怎樣運(yùn)行的!
Node 自身的執(zhí)行模型——事件循環(huán),正是它使得回調(diào)函數(shù)十分普遍?!就扑]學(xué)習(xí):《nodejs 教程》】
在進(jìn)程啟動(dòng)時(shí),Node 便會(huì)創(chuàng)建一個(gè)類似于 while(true)
的循環(huán),每執(zhí)行一次循環(huán)體的過程我 們稱為 Tick
。每個(gè) Tick
的過程就是查看是否有事件待處理,如果有,就取出事件及其相關(guān)的回調(diào) 函數(shù)。如果存在關(guān)聯(lián)的回調(diào)函數(shù),就執(zhí)行它們。然后進(jìn)入下個(gè)循環(huán),如果不再有事件處理,就退 出進(jìn)程
Tick 流程圖
事件循環(huán)是實(shí)現(xiàn) Node.js 非阻塞 I/O 非常重要的一部分! 事件循環(huán),非阻塞 I/O 都是屬于 LIBUV
這個(gè) C++ 庫的底層能力。 理解了 事件循環(huán),非阻塞 I/O 就理解了 Node.js 的異步是怎樣運(yùn)行的!
通過代碼模擬 eventloop
const eventloop = { queue: [], // 循環(huán)方法 loop() { // 不停的檢測(cè)隊(duì)列是否還有未循環(huán)的消息 while (this.queue.length) { const callback = this.queue.shift(); callback(); } // 執(zhí)行下一次循環(huán) // 小知識(shí)點(diǎn) JS的 this綁定 setTimeout(this.loop.bind(this), 50); }, // 添加消息到隊(duì)列 add(callback) { this.queue.push(callback); }, }; eventloop.loop(); setTimeout(() => { eventloop.add(() => { console.log("第一個(gè)"); }); }, 500); setTimeout(() => { eventloop.add(() => { console.log("第二個(gè)"); }); }, 800);