javascript如何工作_它的执行机制是怎样的?

admin 百科 11
JavaScript执行机制核心是调用栈、任务队列和事件循环协同工作:调用栈执行同步代码(LIFO结构),任务队列分宏任务(如setTimeout)和微任务(如Promise.then),事件循环按“宏任务→微任务→渲染→下一宏任务”循环调度。

javascript如何工作_它的执行机制是怎样的?-第1张图片-佛山资讯网

JavaScript 是单线程、非阻塞、基于事件循环的脚本语言,它的执行机制核心在于 调用栈(Call Stack)任务队列(Task Queue)事件循环(Event Loop) 三者协同工作。

调用栈:同步代码的执行容器

JS 引擎执行同步代码时,会把函数调用逐层压入调用栈,执行完就弹出。它是后进先出(LIFO)结构,直观反映当前正在运行的函数链。

  • 全局代码先入栈,执行完毕后出栈
  • 遇到函数调用,函数体入栈;函数返回,立即出栈
  • 栈溢出(如无限递归)会导致 RangeError: Maximum call stack size exceeded

任务队列:分两类,处理异步回调

JS 把异步操作的回调按类型分进两个队列:

  • 宏任务队列(Macrotask Queue):包含 setTimeoutsetIntervalI/OUI 渲染script 标签加载等
  • 微任务队列(Microtask Queue):包含 Promise.then/catch/finallyqueueMicrotask()MutationObserver
  • 微任务优先级高于宏任务:每次宏任务执行完,会清空整个微任务队列,再取下一个宏任务

事件循环:持续协调执行节奏

事件循环是一个不断运行的机制,它按固定顺序检查和调度任务:

立即学习“Java免费学习笔记(深入)”;

标签: javascript java js node.js node 浏览器 mac

发布评论 0条评论)

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