语法:process.nextTick(callback[, …args])
参数:
- callback:回调函数;
- args:回调函数的参数,可选
process.nextTick()方法将 callback 添加到”next tick 队列”。 一旦当前事件循环队列的任务全部完成,在next tick队列中的所有callbacks会被依次调用。
process.nextTick()的回调函数 会再下次事件循环的开始前被调用;而setTimeout 和 setInterval是在下一次事件循环队列中,所以process.nextTick()的callback要早于setTimeout和setInterval执行。
我们来看这样一段代码:
process.nextTick(function(){
console.log("nt1");//执行顺序3
})
setTimeout(function(){
console.log('st');//执行顺序6
},0)
new Promise(function(resolve){
console.log("promise_s");//执行顺序1
resolve();
}).then(function(resolve){
console.log("promise_call");//执行顺序5
})
process.nextTick(function(){
console.log("nt2");//执行顺序4
})
console.log('end');//执行顺序2
//输出结果:
promise_s
end
nt1
nt2
promise_call
st
结果解析:
- promise内部的函数是同步函数,会先执行;
- process.nextTick()的回调函数是异步函数,会再本次事件循环结束后立即执行(即下个事件循环开始前执行);
- Promise的回调函数(then方法)是异步函数,会再本次事件循环结束后立即执行(即下个事件循环开始前执行);但process.nextTick()的执行早于Promise.then的执行;
- 而setTimeout 和 setInterval亦是异步函数,但在下一次事件循环队列中执行;
- 异步事件包括本轮和次轮事件循环,本轮循环先于次轮循环执行,而Promise.then()是本轮事件循环,而setTimeout和setInterval是次轮事件循环。