4-2 js运行机制

  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运行机制)