
JS异步之宏队列与微队列
原理图
发布日期:2021-05-04 17:18:04
浏览次数:37
分类:技术文章
本文共 1463 字,大约阅读时间需要 4 分钟。
原理图
JS中用来存储待执行回调函数的队列包含2个不同特定的列队
- 宏列队:用来保存待执行的宏任务(回调),比如:定时器回调/DOM事件回调/ajax回调
- 微列队:用来保存待执行的微任务(回调),比如:promise的回调/MutationObserver的回调
JS执行时会区别这2个队列
- JS引擎首先必须先执行所有的初始化同步任务代码
- 每次准备取出第一个宏任务执行前,都要将所有的微任务一个一个取出来执行。当该宏任务执行完成,会检查其中的微任务队列,如果为空则直接执行下一个宏任务,如果不为空,则
依次执行微任务
,执行完成才去执行下一个宏任务。 - 引入微任务的初衷是为了解决异步回调的问题
macrotask(宏任务)
在浏览器端,其可以理解为该任务执行完后,在下一个macrotask执行开始前,浏览器可以进行页面渲染。触发macrotask任务的操作包括:dom事件回调,ajax回调,定时器回调
script(整体代码) setTimeout、setInterval、setImmediate I/O、UI交互事件 postMessage、MessageChannelmicrotask(微任务)
可以理解为在macrotask任务执行后,页面渲染前立即执行的任务。触发microtask任务的操作包括:
Promise回调:Promise.then Mutation回调:MutationObserver process.nextTick(Node环境)setTimeout(() => { // 会立即放入宏列队 console.log('timeout callback1()') // 每次准备取出第一个宏任务执行前,都要将所有的微任务一个一个取出来执行 Promise.resolve(3).then( value => { // 会立即放入微列队 console.log('Promise onResolved3()', value) } )}, 0)setTimeout(() => { // 会立即放入宏列队 console.log('timeout callback2()')}, 0)Promise.resolve(1).then( value => { // 会立即放入微列队 console.log('Promise onResolved1()', value) }) Promise.resolve(2).then( value => { // 会立即放入微列队 console.log('Promise onResolved2()', value) })
依次输出
- Promise onResolved1() 1
- Promise onResolved2() 2
- timeout callback1()
- Promise onResolved3() 3
- timeout callback2()
可能存在的问题
如果一个Microtask队列太长,或者执行过程中不断加入新的Microtask任务,会导致下一个Macrotask任务很久都执行不了。结果就是,你可能会遇到UI一直刷新不了,或者I/O任务一直完成不了。 或许是考虑到了这一点,Microtask queue中的process.nextTick任务,是被设置了(在一个事件循环中的)最大调用次数process.maxTickDepth的,默认是1000。一定程度上避免了上述情况。发表评论
最新留言
不错!
[***.144.177.141]2025年03月12日 19时13分02秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
java并发学习24:固定运行顺序模式
2019-03-04
html5学习9:HTML5文档结构详解
2019-03-04
介绍一个不错的分析客户价值的模型RFM
2019-03-04
SpringMVC---使用
2019-03-04
2.2.4 加减法运算和溢出判断更换
2019-03-04
2.2.6 强制类型转换
2019-03-04
计算机网络教程 谢希仁 第三章 数据链路层
2019-03-04
Redis缓存数据的处理流程
2019-03-04
Linux:文件句柄泄漏问题
2019-03-04
Linux:多线程简介
2019-03-04
【java】227. 基本计算器 II---思路简单,代码清晰!!!
2019-03-04
【java】115. 不同的子序列----学会动态规划,时间复杂度O(n^2)!!!
2019-03-04
【java】368. 最大整除子集---使用动态规划,快速解决子问题!!!
2019-03-04
莫比乌斯函数
2019-03-04
HDU - 6514 Monitor(二维差分+二维前缀和)
2019-03-04
LINUX延时函数使用
2019-03-04
数据结构第七章(图---总结一)
2019-03-04
2020-12-24
2019-03-04