Node中setTimeout和setImmediate的执行顺序问题
setTimeout(() => {
console.log('setTimeout')
}, 0)
setImmediate(() => {
console.log('setImmediate')
})
执行多次后会发现出现两种执行结果:
分别是 setTimeout setImmediate 和 setImmediate setTimeout
原因:
Node中的libuv在遇到setTimeout函数时,会立即执行setTimeout函数,将其回调函数放入一个树结构中存储,虽然说设置延迟0ms,但是这个存储过程会消耗时间,假设是10ms将回调函数放入树结构,然后延迟0ms将其放入事件队列,这个过程花费了10ms
当node执行完main script时会初始化事件循环
假设当这个初始化花费的时间大于10ms时,也就是说在事件循环初始化前setTimeout的回调函数就被放入了timer事件队列,这时就会按照顺序依次执行setTimeout setImmediate
假设当初始化事件循环的时间小于10ms时,也就是说在setTimeout回调函数被放入timer事件队列前,事件循环就已经初始化了,这时事件队列中还没有setTimeout的回调函数,所以会先执行setImmediate,当执行到第二次tick时才会执行setTimeout的回调函数,所以此时的打印顺序为 setImmediate setTimeout