美文网首页
4-2 js运行机制

4-2 js运行机制

作者: 一杯浊酒 | 来源:发表于2019-04-26 01:43 被阅读0次
    1. 如何理解JS 的单线程?
    • 单线程: JS 在运行的时候,同一时间只能做一件事儿
    • setTimeout是一个异步任务,console.log是同步任务
    1. 什么是任务队列?
    • 单线程任务队列:单线程任务队列是有优先顺序的,在任务里是有同步任务和异步任务,同步任务执行的优先级是高于异步的

       for (var i = 0;i < 4;i++) {
                 setTimeout(function() {
                  console.log(i)
                 },1000)
                 
             }
      //打印出4个4
      

    • 异步队列执行的时间(异步任务的放入时间和执行时间),浏览器有一个执行 setTimeout 和 setInterval 的 panel ,它是到了那个时间才会把那个语句放到异步队列的过程中,我这个for 循环在执行过程中,遇到setTimeout 了,这个地方是1000,那么定时器会记录这个语句,然后它并没有去执行,i 就加1了,然后还是没有执行,只是交给定时器模块了,这个时候for 循环体在执行的过程中,并没有真正放到异步队列中去,按照刚才讲的,for 循环体执行完了就会去执行异步队列,也就是说依次执行setTimeout,但其实这个时候异步执行队列中是没有setTimeout的,因为它没有到时间,4个循环体执行是非常块的,可能不到1ms就执行完了,它执行完了异步队列里并没有东西,只有当这个时间到了,定时器会把setTimeout 函数体扔到异步队列中,异步队列在等待一个叫事件循环的东西来执行,可以理解为现在到时间了,扔到异步队列了,异步队列就可以执行了

    1. 什么是 Event loop?

    相关文章

      网友评论

          本文标题: 4-2 js运行机制

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