JavaScript:事件循环机制(EventLoop)
warning:
这篇文章距离上次修改已过180天,其中的内容可能已经有所变动。
JavaScript的事件循环机制是一种异步处理的方式,主要用于处理执行栈中的任务以及其他异步任务(例如网络请求、用户输入等)。
事件循环分为宏任务(MacroTask)和微任务(MicroTask)。宏任务通常包括脚本(全部代码)、setTimeout、setInterval、I/O、UI 交互等,微任务则包括 Promise、MutationObserver 等。
事件循环的简化流程如下:
- 执行同步代码,遇到异步代码(如setTimeout、Promise等),将其回调函数注册,但不立即执行。
- 执行栈为空时,检查微任务队列,执行所有微任务。
- 执行栈为空时,检查宏任务队列,执行一个宏任务,然后再次检查并执行所有微任务。
- 循环执行步骤2至3,直到全部任务完成。
以下是一个简单的例子,演示了事件循环机制的应用:
console.log('script start');
setTimeout(function() {
console.log('setTimeout');
}, 0);
Promise.resolve().then(function() {
console.log('promise');
}).then(function() {
console.log('promise2');
});
console.log('script end');
// 输出顺序为:
// script start
// script end
// promise
// promise2
// setTimeout
在这个例子中,首先执行同步代码,然后注册setTimeout和Promise,之后执行栈为空,所以先执行微任务(先promise,然后promise2),然后执行一个宏任务(即setTimeout),最后再次执行微任务(如果有的话),然后再执行下一个宏任务。这个过程一直重复,直到所有任务都被处理完毕。
评论已关闭