美文网首页
JS运行机制

JS运行机制

作者: Zero_R | 来源:发表于2019-02-18 20:12 被阅读0次

JS异步任务分类:

1. setTimeout和setInterval
2. DOM事件
3. ES6中的Promise
以上都属于异步任务


两个问题引出JS运行机制

题目1:
console.log(1);
setTimeout(function(){
    console.log(3);
},0);
console.log(2);
//1
//2
//3
同步任务与异步任务优先级

为什么会输出123而不是132呢?
注:延时参数0不代表立即执行,现在浏览器最小延时为4ms,以前是10ms,小于4ms都会以4ms延时处理
setTimeout属于异步任务,JS引擎会将异步任务挂起,优先执行同步任务,所有同步任务执行完毕后才会执行异步任务。


题目2:
for(var i = 0; i < 4; i++){
  setTimeout(function(){
    console.log(i);
  },0);
}
//4
//4
//4
//4
异步任务挂起时间执行时间

为什么会输出4个4而不是0123呢?
for循环(同步任务)完成后才会执行console.log(i),而这时候i已经变为4,所以输出4个4。而let定义i则不出现这样的问题。


任务队列和Event Loop

首先看下图:


任务队列和Event Loop
  1. 运行栈中遇到异步任务setTimeout会将异步任务放入定时器模块(当延时触发时定时器模块将任务放入任务队列中)。
  2. 所有同步任务执行完成后会监听任务队列中是否有任务,如果有任务则再放入运行栈中执行。

这个过程就称之为Event Loop。
每种异步任务都有相对应的处理模块。


注2:只有同步任务执行完成后才会去读取任务队列中的任务。比如死循环前面有异步任务,但是异步任务依旧不会执行。

setTimeout(function(){
    console.log(3);
},0);
while(true){

}
console.log(2);

这里的3和2不会输出,因为while(同步任务)没有执行完成,所以不会读取任务队列中的任务。

相关文章

  • 最全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在同一...

  • JS运行机制

    JS运行机制 如果一个文档流中包含多个script代码段(用script标签分隔的js代码或引入的js文件),运行...

网友评论

      本文标题:JS运行机制

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