美文网首页
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运行机制

    如何理解JS 的单线程? 单线程: JS 在运行的时候,同一时间只能做一件事儿 setTimeout是一个异步任务...

  • 最全js运行机制

    js运行机制

  • js new 运行机制

    js手札--js中new到底做了些啥JS核心系列:理解 new 的运行机制深入理解 Javascript 运行机制及原型

  • 浅析Vue.nextTick()原理

    1、为什么用Vue.nextTick() 首先来了解一下JS的运行机制。 JS运行机制(Event Loop) J...

  • 运行机制,宏任务 与 微任务

    运行机制: JS 的本质是单线程执行 事件队列:同步任务,异步任务() 运行机制 1,JS 的本质是单线程执行 单...

  • 前端知识点

    JS 1. 事件循环 「硬核JS」一次搞懂JS运行机制[https://juejin.cn/post/684490...

  • js运行机制

    js运行机制 在日常面试求职中,不免会做几道面试题,这面试题中往往会遇到js执行输出顺序,而这运行机制是我们每个前...

  • Event Loop

    关于浏览器的多进程,JS单线程等涉及浏览器整体运行机制、浏览器内核、JS运行机制,请看这篇文章,全是干货,什么时候...

  • JS的运行机制

    title: JS的运行机制date: 2018-12-28 11:02:52tags: js 为什么JavaSc...

  • JavaScript执行机制、Event Loop

    一、运行机制 JavaScript是单线程运行机制。 为什么JavaScript是单线程?单线程就是说,js在同一...

网友评论

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

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