Node 11.0.0 添加queueMicrotasks
为实验性的。该文档说它类似于process.nextTick
但队列由 V8 而不是 Node.js 管理。要使用的用例queueMicrotasks
是process.nextTick
什么?使用一个比另一个会有任何性能提升吗?
F.b*_*nal 19
我们可以找到不同的队列(在完成函数/脚本执行后按检查优先级顺序显示):
如何检查队列?
首先,检查 nextTick 队列以获取任务执行,一旦耗尽,检查 microTasks 队列。在完成微任务队列中的任务后,重复检查 nextTick 和微任务队列的过程,直到队列被清空。
下一个要检查的队列是计时器,最后是立即队列。
是一样的,两者的方式都是在当前函数或脚本执行后才执行任务。
他们有不同的队列。nextTick 的队列由节点管理,微任务由 v8 管理。
这是什么意思?
在当前函数/脚本执行后首先检查 nextTick 队列,然后是 microTask 队列。
没有性能提升,区别在于在函数/脚本执行后将首先检查 nextTick 队列,并且必须考虑到这一点。如果您从不使用 nextTick 并且只使用 queueMicrotask 您将拥有与仅使用 nextTick 相同的行为(考虑到您的任务将与另一个微任务一起放入队列中)
用例可能是在任何微任务之前执行任务,例如,在 promise then 和/或 catch 之前。值得注意的是,promise 使用微任务,因此,添加到 then/catch 的任何回调都将添加到微任务队列中,并在 nextTick 队列为空时执行。
执行这段代码后:
function task1() {
console.log('promise1 resolved');
}
function task2() {
console.log('promise2 resolved');
process.nextTick(task10);
}
function task3() {
console.log('promise3 resolved');
}
function task4() {
console.log('immediate 1');
}
function task5() {
console.log('tick 1');
}
function task6() {
console.log('tick 2');
}
function task7() {
console.log('microtask 1');
}
function task8() {
console.log('timeout');
}
function task9() {
console.log('immediate 2');
}
function task10() {
console.log('tick3');
queueMicrotask(task11);
}
function task11() {
console.log('microtask 2');
}
Promise.resolve().then(task1);
Promise.resolve().then(task2);
Promise.resolve().then(task3);
setImmediate(task4);
process.nextTick(task5);
process.nextTick(task6);
queueMicrotask(task7);
setTimeout(task8, 0);
setImmediate(task9);
Run Code Online (Sandbox Code Playgroud)
第一步:执行nextTick队列中的所有任务
输出:
第二步:执行microTasks队列中的所有任务
输出:
第三步:执行nextTick队列中的所有任务(微任务(task2)的执行增加了一个新任务)
输出:
第四步:执行microTasks队列中的所有任务(有一个新任务是由task10的执行添加的)
输出:
第五步:nextTick 和 microTasks 队列中不再有任务,next 执行定时器队列。
输出:
第 6 步:(过期)定时器队列中不再有任务,执行立即队列中的任务
输出:
正如我们所看到的,选择一个或另一个没有性能原因,选择的决定取决于我们的需求以及需要做什么以及何时完成。
想象一下这段代码:
let i = 1;
queueMicrotask(() => console.log(i));
process.nextTick(() => i++);
Run Code Online (Sandbox Code Playgroud)
由于首先首先检查 nextTick 队列,因此输出将为 2。
但如果你这样做
let i = 1;
queueMicrotask(() => console.log(i));
process.nextTick(() => queueMicrotask(() =>i++));
Run Code Online (Sandbox Code Playgroud)
你会得到1。
通过示例,我想让您看到用例来自您对需要执行任务的内容和时间的需求。重要的是考虑到承诺中的 then/catch 回调是微任务,将在 nextTick 任务之后执行,考虑到这对于避免错误很重要(如后面的示例中所述)。
归档时间: |
|
查看次数: |
2300 次 |
最近记录: |