什么是事件循环,宏任务和微任务
时间: 2023-12-24 09:15:26 浏览: 149
事件循环是 JavaScript 运行时的一种机制,用于处理异步代码。JavaScript 是单线程的,即一次只能执行一条语句。当 JavaScript 运行到一个异步操作时(例如定时器、Ajax 请求、Promise 等),它会将异步操作加入到事件队列中,然后继续执行后面的同步代码,直到异步操作完成并被添加到了任务队列中。事件循环会不断地从任务队列中获取任务并执行,直到队列为空。
宏任务是指由浏览器或 Node.js 提供的任务,例如 setTimeout、setInterval、setImmediate、I/O 操作、UI 渲染等。当事件循环从任务队列中获取宏任务时,会将当前执行的上下文挂起,然后执行宏任务的代码,直到宏任务执行完毕,事件循环才会继续执行下一个任务。
微任务是指由 JavaScript 引擎提供的任务,例如 Promise 的 then 方法、MutationObserver 等。当宏任务执行完毕后,事件循环会立即执行所有微任务,直到微任务队列为空为止,然后再从宏任务队列中取出下一个宏任务执行,这样可以优先处理微任务,保证及时更新 UI。
相关问题
JS事件循环,宏任务、微任务
JS事件循环是指在JavaScript中,代码的执行是按照事件循环机制进行的。事件循环是一个持续执行的过程,它不断地将待执行的任务从任务队列中取出并执行。在事件循环中,任务分为同步任务和异步任务,异步任务又分为宏任务和微任务。
宏任务是由宿主环境提供的异步任务,比如setTimeout、setInterval等。宏任务会被放入宏任务队列中,只有当执行栈为空时,宏任务才会被执行。
微任务是由JavaScript引擎自身发起的异步任务,比如Promise的回调函数、MutationObserver等。微任务会被放入微任务队列中,在执行栈被清空之后立即执行。
在事件循环中,每次循环都会从宏任务队列中取出一个宏任务执行,然后检查微任务队列是否为空,如果不为空,则依次取出并执行微任务,直到微任务队列为空。然后再从宏任务队列中取出下一个宏任务,依次循环。
“事件循环中分为宏任务队列和微任务队列”这个怎么理解,宏任务队列什么,微任务队列又是什么?怎么才能判断哪些操作是在宏任务队列,哪些任务在微任务队列
事件循环是 JavaScript 的一个执行机制,它负责管理代码执行的顺序。在事件循环中,分为宏任务队列和微任务队列,这两个队列分别用于存储不同类型的任务。
宏任务队列中存储的是一些比较耗时的、需要异步执行的任务,例如 setTimeout、setInterval、ajax 等。宏任务队列的执行顺序是先进先出。
微任务队列中存储的是一些轻量级的、需要在当前任务执行完之后立即执行的任务,例如 Promise 的 then、catch、finally,MutationObserver 等。微任务队列的执行顺序也是先进先出。
我们可以使用一些规则来判断哪些任务在宏任务队列,哪些任务在微任务队列。
- 首先,promise.then/catch 方法中的回调函数会被放入微任务队列中。
- 其次,将 MutationObserver 监听的回调函数放入微任务队列中。
- 接着,setTimeout/setInterval/setImmediate 等定时器产生的回调函数将被放入宏任务队列中。
- 最后,UI render、I/O 等事件会被放入宏任务队列中。
当执行完一个宏任务之后,会自动执行微任务队列中的所有任务,直到微任务队列为空,然后再执行下一个宏任务。这就是事件循环的运行机制。
阅读全文