推广

大白话讲解JavaScript 执行机制,一看就懂

iseeyu2年前 (2024-02-21)推广132

运行机制.png

我们解释一下这张图:

1、同步和异步任务分别进入不同的执行”场所”,同步的进入主线程,异步的进入Event Table并注册函数。
2、当指定的事情完成时,Event Table会将这个函数移入Event Queue。
3、主线程内的任务执行完毕为空,会去Event Queue读取对应的函数,进入主线程执行。
上述过程会不断重复,也就是常说的Event Loop(事件循环)。(Event Loop是javascript的执行机制)

优先级
setTimeout()、setInterval()
setTimeout() 和 setInterval() 产生的任务是 异步任务,也属于 宏任务。
setTimeout() 接受两个参数,第一个是回调函数,第二个是推迟执行的毫秒数。
如果将第二个参数设置为0或者不设置,意思 并不是立即执行,而是指定某个任务在主线程最早可得的空闲时间执行,也就是说,尽可能早得执行。它在”任务队列”的尾部添加一个事件,因此要等到同步任务和”任务队列”现有的事件都处理完,才会得到执行。(画重点)
所以说,setTimeout() 和 setInterval() 第二个参数设置的时间并不是绝对的,它需要根据当前代码最终执行的时间来确定的

Promise
Promise 相对来说就比较特殊了,在 new Promise() 中传入的回调函数是会 立即执行 的,但是它的 then() 方法是在 执行栈之后,任务队列之前 执行的,它属于 微任务。

大白话讲解JavaScript 执行机制,一看就懂

process.nextTick
process.nextTick 是 Node.js 提供的一个与”任务队列”有关的方法,它产生的任务是放在 执行栈的尾部,并不属于 宏任务 和 微任务,因此它的任务 总是发生在所有异步任务之前。

setImmediate
setImmediate 是 Node.js 提供的另一个与”任务队列”有关的方法,它产生的任务追加到”任务队列”的尾部,它和 setTimeout(fn, 0) 很像,但优先级都是 setTimeout 优先于 setImmediate。
有时候,setTimeout 的执行顺序会在 setImmediate 的前面,有时候会在 setImmediate 的后面,这并不是 node.js 的 bug,这是因为虽然 setTimeout 第二个参数设置为0或者不设置,但是 setTimeout 源码中,会指定一个具体的毫秒数(node为1ms,浏览器为4ms),而由于当前代码执行时间受到执行环境的影响,执行时间有所起伏,如果当前执行的代码小于这个指定的值时,setTimeout 还没到推迟执行的时间,自然就先执行 setImmediate 了,如果当前执行的代码超过这个指定的值时,setTimeout 就会先于 setImmediate 执行。

通过上面的介绍,我们就可以得出一个代码执行的优先级:
同步代码(宏任务) > process.nextTick > Promise(微任务)> setTimeout(fn)、setInterval(fn)(宏任务)> setImmediate(宏任务)> setTimeout(fn, time)、setInterval(fn, time),其中time>0

面试回答
面试中该如何回答呢? 下面是我个人推荐的回答:
首先js 是单线程运行的,在代码执行的时候,通过将不同函数的执行上下文压入执行栈中来保证代码的有序执行。
在执行同步代码的时候,如果遇到了异步事件,js 引擎并不会一直等待其返回结果,而是会将这个事件挂起,继续执行执行栈中的其他任务
当同步事件执行完毕后,再将异步事件对应的回调加入到与当前执行栈中不同的另一个任务队列中等待执行。
任务队列可以分为宏任务对列和微任务对列,当当前执行栈中的事件执行完毕后,js 引擎首先会判断微任务对列中是否有任务可以执行,如果有就将微任务队首的事件压入栈中执行。
当微任务对列中的任务都执行完成后再去判断宏任务对列中的任务。

面试遇到的题总结
1、同步和异步的区别是什么?分别举一个同步和异步的例子
同步会阻塞代码执行,而异步不会。alert是同步,setTimeout是异步

2、为何需要异步呢?
如果第一个示例中间步骤是一个 ajax 请求,现在网络比较慢,请求需要5秒钟。如果是同步,这5秒钟页面就卡死在这里啥也干不了了。

最后,前端 JS 脚本用到异步的场景主要有两个:

  • 定时 setTimeout setInverval
  • 网络请求,如 ajax 加载
  • 事件绑定

3、写出下图执行顺序

image.jpeg

执行顺序是2431
在 new Promise() 中传入的回调函数是 立即执行 的,但是它的 then() 方法是在 执行栈之后,任务队列之前 执行的,
.then是回调函数,链式回调,会被放在挂起,等待执行栈的内容执行完后(输出4)再回调(输出3),最后执行异步的1

扫描二维码推送至手机访问。

版权声明:本文由西安泽虎代运营发布,如需转载请注明出处。

转载请注明出处https://0291.com.cn/post/57292.html

相关文章

网站友链对网站优化排名的好处。

网站友链对网站优化排名的好处。

SEO在优化站点时,经常与其他站点交换链接,这个站点既是一个环节,又叫友情链接。但我们不能小看这些链接在我们的网站中的作用。无论在改善流量和改善用户体验方面,都有明显的好处。那么友情链对到网站优化的优势是什么呢? 一、友情链接的作用 1,加强搜索引擎到网页的数量: 友情链接可以给...

如何撰写整合营销传播方案?

岁末年初是许多甲方招开比稿的时间,比的多是年度规划或是IMC方案,IMC是整合传播的简称,作为该如何下笔撰写呢?一、方案类型1. 品牌年度传播规划:分析品牌现况,并设定一年后要达到的目标需要根据品牌的主张,延伸年度的沟通主轴根据主轴发想,思考可结合的资源或大事件如果一年中有...

新媒体运营推广策划撰写技巧!

新媒体运营推广策划撰写技巧!

新媒体运营如何写推广策划案,我把它分为几部分,抛砖引玉,分享完大家讨论,对该主题进行互动交流。 新媒体运营推广策划案包括内容大致如下: 一、 运营是什么?新媒体运营是什么? 二 、指定目标 三、 做预算 四、写方案 五、问题解答 下面分别展开给大家做详细介绍 一 、运营...

关键词、文章质量对网站排名的影响。

关键词、文章质量对网站排名的影响。

关键词、文章质量是对网站排名有很大影响的,今天SEO优化中心网站SEO为大家展开说说每一个关键点对于网站优化的影响体现,对于大家开展优化工作也有帮助。 1、一般来说,原创文章是最好的,但是一定要跟关键词相关,原创文章是一定会收录的,只不过是时间的问题,就像世界上没有同样的两篇树叶,因为搜索引擎来的...

手游行业优化方法论 ,经典素材案例打包给你!

手游行业优化方法论 ,经典素材案例打包给你!

不久前,腾讯发布了Q2季度财报,在《王者荣耀》的带领下,手游收入同比增长了54%,约148亿元人民币,首次超过PC端游戏收入。   大厂如此强势,也会通过各种推广渠道,做营销、买量,其他游戏厂商更是在推广上狠砸钱,信息流广告更是手游买量必争之地。  ...

北京SEO优化公司:理清SEO思路。

北京SEO优化公司:理清SEO思路。

很多时候我们在做SEO优化的时候会发现,一个网站我们很用心的SEO优化它排名反而很难上来,而一些我们自己平时就简单的发布网站信息、这个网站的排名反而很好。这是为什么呢??下面SEO优化中心SEO告诉你,往下看: 一、SEO优化心态问题: 首先优化一个网站,特别是一些网站关键词比较热门的...

现在,非常期待与您的又一次邂逅

我们努力让每一部企业宣传片和抖音短视频成为商业大片