zoukankan      html  css  js  c++  java
  • 宏队列与微队列

    1,宏队列:用来保存 待执行的宏任务(回调),

           比如:定时器回调 、DOM事件回调、ajax回调

    2,微队列:用来保存待执行的微任务(回调),

           比如:promise的回调、MutationObserve的回调

    3,JS执行时会区别这 2个队列

      JS引擎首先必须先执行所有的初始化同步任务代码

      每次准备取出第一个宏任务执行前,都要将所有的微任务一个一个取出来执行

        setTimeout(()=>{  //立即放入宏队列
            console.log('setTimeout1')
            Promise.resolve(3).then(
             value => {  //立即放入微队列
               console.log('onResolved3()', value)
             }
            )
        },0)
    
        setTimeout(()=>{  //立即放入宏队列
          console.log('setTimeout2')
        },0)
    
        Promise.resolve(1).then(
          value => {  //立即放入微队列
            console.log('onResolved1()', value)
            setTimeout(()=>{
              console.log('setTimeout3', value)
            },0)
          }
        )
    
       Promise.resolve(2).then(
         value => {  //立即放入微队列
           console.log('onResolved2()', value)
         }
       )
    

     setTimeout(() => {
                console.log("0")
            }, 0)
            new Promise((resolve, reject) => {
                console.log("1")
                resolve()
            }).then(() => {
                console.log("2")
                new Promise((resolve, reject) => {
                    console.log("3")
                    resolve()
                }).then(() => {
                    console.log("4")
                }).then(() => {
                    console.log("5")
                })
            }).then(() => {
                console.log("6")
            })
    
            new Promise((resolve, reject) => {
                console.log("7")
                resolve()
            }).then(() => {
                console.log("8")
            })
    

    1 7 2 3 8 4 6 5 0

  • 相关阅读:
    福大软工 · 第七次作业
    git分支重命名
    vscode左侧文件不同颜色标识含义
    正则表达式匹配指定字符区间的内容,且不包含指定字符
    git如何撤销工作区的修改
    git查看某个文件的提交历史
    扫盲篇--远程桌面连接
    git merge后如何撤销
    element-ui+vue-treeselect校验
    typeof 踩坑总结
  • 原文地址:https://www.cnblogs.com/shanlu0000/p/12985494.html
Copyright © 2011-2022 走看看