javascript事件循环如何工作_异步编程有哪些常见误区

admin 百科 13
事件循环按“同步→微任务(全清)→宏任务(一个)”节拍运转:先执行所有同步代码,再清空微任务队列,最后执行一个宏任务。

javascript事件循环如何工作_异步编程有哪些常见误区-第1张图片-佛山资讯网

JavaScript事件循环不是“等一个任务做完再做下一个”,而是用一套明确的调度规则,让单线程也能高效响应用户、处理网络请求、执行动画,还不卡页面。关键在于它分清了同步代码、微任务、宏任务三类工作,并严格按顺序交接控制权。

事件循环怎么一步步运转

每次循环只做三件事,且顺序固定:

  • 先跑完所有当前同步代码(比如函数调用、console.log、变量赋值)
  • 同步代码一结束,立刻清空全部微任务(Promise.then、queueMicrotask、MutationObserver回调)——哪怕新微任务在执行中产生,也会被本轮继续处理完
  • 微任务队列空了,才从宏任务队列里取一个任务执行(比如setTimeout、setInterval、DOM事件、I/O回调)

这个“同步 → 微任务(全清)→ 宏任务(一个)→ 循环”就是核心节拍。它确保Promise总比setTimeout快,也解释了为什么连续两个setTimeout(0)不会并行执行,而是排队。

异步编程中最容易踩的三个坑

误区不在语法,而在对执行时机的直觉偏差:

标签: javascript java ai 为什么

发布评论 0条评论)

还木有评论哦,快来抢沙发吧~