美文网首页让前端飞Web前端之路
前端笔记(4)JavaScript宏观与微观任务

前端笔记(4)JavaScript宏观与微观任务

作者: sullay | 来源:发表于2019-09-28 23:54 被阅读0次

    宏观和微观任务

    在 ES3 和更早的版本中,JavaScript 本身还没有异步执行代码的能力,这也就意味着,宿主环境传递给 JavaScript 引擎一段代码,引擎就把代码直接顺次执行了,这个任务也就是宿主发起的任务。

    但是,在 ES5 之后,JavaScript 引入了 Promise,这样,不需要浏览器的安排,JavaScript 引擎本身也可以发起任务了。

    由于我们这里主要讲 JavaScript 语言,那么采纳 JSC 引擎的术语,我们把宿主发起的任务称为宏观任务,把 JavaScript 引擎发起的任务称为微观任务。

    宏观任务的队列就相当于事件循环。在宏观任务中,JavaScript 的 Promise 还会产生异步代码,JavaScript 必须保证这些异步代码在一个宏观任务中完成,因此,每个宏观任务中又包含了一个微观任务队列。

    有了宏观任务和微观任务机制,我们就可以实现 JavaScript 引擎级和宿主级的任务了,例如:Promise 永远在队列尾部添加微观任务。setTimeout 等宿主 API,则会添加宏观任务。

    如何分析异步执行的顺序

    1. 首先我们分析有多少个宏任务;
    2. 在每个宏任务中,分析有多少个微任务;
    3. 根据调用次序,确定宏任务中的微任务执行次序;
    4. 根据宏任务的触发规则和调用次序,确定宏任务的执行次序;
    5. 确定整个顺序。
    setTimeout(()=>{console.log('c')},0)
    let x = new Promise((resolve,reject)=>{
        console.log('a')
        resolve()
    }).then(res=>{
        console.log('b')
        setTimeout(()=>{console.log('d')},0)
    })
    

    相关文章

      网友评论

        本文标题:前端笔记(4)JavaScript宏观与微观任务

        本文链接:https://www.haomeiwen.com/subject/ojksyctx.html