美文网首页
微任务和宏任务的区别

微任务和宏任务的区别

作者: 李小白呀 | 来源:发表于2021-07-20 18:00 被阅读0次

微任务和宏任务

  1. 宏任务:当前调用栈中执行的代码成为宏任务。(主代码快,定时器等等)。

2.微任务: 当前(此次事件循环中)宏任务执行完,在下一个宏任务开始之前需要执行的任务,可以理解为回调事件。(promise.then,proness.nextTick等等)。

  1. 宏任务中的事件放在callback queue中,由事件触发线程维护;微任务的事件放在微任务队列中,由js引擎线程维护。

js执行顺序,(先执行宏任务列,微任务队列)

运行机制

  1. 在执行栈中执行一个宏任务。

  2. 执行过程中遇到微任务,将微任务添加到微任务队列中。

  3. 当前宏任务执行完毕,立即执行微任务队列中的任务。

  4. 当前微任务队列中的任务执行完毕,检查渲染,GUI线程接管渲染。

  5. 渲染完毕后,js线程接管,开启下一次事件循环,执行下一次宏任务(事件队列中取)。

微任务:processnextTickMutationObserverPromise.thencatchfinally

宏任务:I/OsetTimeoutsetIntervalsetImmediaterequestAnimationFrame

代码示例

1.正常循环输出

 for(var i=0;i<10;i++){
   console.log(i);
 }

#0 1 2 3 4 5 6 7 8 9

2.循环里面使用了var,发生了变量提升,相当于这个i是定义在for循环外部的,所以10次循环结束后,定时器执行输出10次外部的i,也就是10个10

for(var i=0;i<10;i++){
      console.log(1,i);
      setTimeout(function(){
        console.log(2,i);
     },10)
  }
image.png

3.使用块级变量声明let代替var,setTimeOut中每次都有生成一个新的函数,这个函数会拷贝要使用的变量到它的块级作用域里,也就是i,也就是说,每个函数都有一个自己的i,因此会按顺序输出1到10。

for(let i=0;i<10;i++){
      setTimeout(function(){
        console.log(i);
      },10)
  }

#0 1 2 3 4 5 6 7 8 9

闭包:内部的setTimeOut里的函数因为作用域继承,还可以访问块级作用域的变量i,也可以访问上一层setTimeOut里函数定义的变量),此时访问的就是闭包

    for (let i = 0; i < 10; i++) {
      setTimeout(function () {
        console.log(1, i);
        var k=i+3
        setTimeout(function () {//闭包
          console.log(2, i);
          console.log('k', k);
        }, 10)
      }, 10)
    }

   #i : 0 1 2 3 4 5 6 7 8 9
   #k: 3 4 5 6 7 8 9 10 11 12

4.拓展(先执行宏任务列,微任务队列)

    setTimeout(function () {
      console.log(1);
    }, 0)
    new Promise(function (resolve, reject) {
      resolve('成功')
      console.log(2);
    }).then(
      console.log(3)
    )
    console.log(4);

    #2 3 4 1

整个script是个宏任务 它下边的代码都是子任务,这些任务分为宏任务和微任务,其中还可以细分为同步和异步 ,promise是同步任务队列,它的回调 .then . catch .finally 是异步队列。先执行宏任务 再看本次宏任务下是否有微任务,有就执行完毕再开启下一轮的宏任务

    setTimeout(function () {
      console.log(1);
    }, 0)
    new Promise(function (resolve, reject) {
      resolve('成功')
      console.log(2);
    }).then(() => {
      console.log(3)
    })
    console.log(4);

    #2 4 3 1
 console.log(0);
    setTimeout(function () {
      console.log(1);
    }, 0)
    new Promise(function (resolve, reject) {
      resolve('成功')
      console.log(2);
    }).then(() => {
      console.log(3)
    }).then(() => {
      console.log(4)
    })
    console.log(5);

   #0 2 5 3 4 1

相关文章

  • 浏览器的事件机制-Eventloop

    循环机制前,我们先要会区分:宏任务与微任务 宏任务Task与微任务Microtask JS中的宏任务和微任务的区别...

  • 微任务和宏任务的区别

    微任务和宏任务 宏任务:当前调用栈中执行的代码成为宏任务。(主代码快,定时器等等)。 2.微任务: 当前(此次事件...

  • 微任务和宏任务@小四@王云飞

    微任务和宏任务 微任务 和 宏任务 表示异步任务的两种分类。 微任务(microtask)和宏任务(macrota...

  • 宏任务和微任务

    [js 宏任务和微任务] .宏任务(macrotask )和微任务(microtask ) macrotask 和...

  • 宏任务 和 微任务

    宏任务: 当前调用栈执行的代码成为宏任务,(主代码块和定时器)也或者宿主环境提供的叫宏任务 这些任务包括: 渲染事...

  • 宏任务和微任务

    介绍这个之前, 建议先了解一下事件循环[https://www.jianshu.com/p/106867eee55...

  • 宏任务和微任务

    浏览器是多线程执行代码,渲染的。但是浏览器只给JS一个线程来执行,因此JS是单线程。因此代码都是同步执行的,但是J...

  • # 宏任务和微任务

    首先说明 首先在JavaScript中,有同步代码和异步代码.这点很清晰. 代码的执行优先级顺序是,同步代码执行优...

  • 微任务和宏任务

    JS是单线程的,可以把这个线程叫做主线程,主线程中包含宏任务队列和微任务队列,宏任务所在的队列就叫宏任务队列,微任...

  • 宏任务和微任务

    所谓微任务和宏任务 宏任务::常见的定时器,用户交互事件等等。可以理解是每次执行栈执行的代码就是一个宏任务。(宏任...

网友评论

      本文标题:微任务和宏任务的区别

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