推广

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

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

运行机制.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://www.0291.com.cn/post/57292.html

相关文章

淘宝客定向计划在哪里展现

淘宝客定向计划在哪里展现

淘宝客是一种按成交计费的推广模式,也指通过推广赚取收益的一类人,淘宝客只要从淘宝客推广专区获取商品代码,任何买家经过您的推广进入淘宝卖家店铺完成购买后,就可得到由卖家支付的佣金。...

我来分享美团亮相昆明旅交会助力目的地营销推广。

我来分享美团亮相昆明旅交会助力目的地营销推广。

今日,2022中国国际旅游交易会(以下简称“旅交会”)在滇池国际会展中心举行。 据悉,美团以目的地整合营销推广、多码合一智慧化解决方案、文旅大数据专项报告等多个文旅服务和产品亮相旅交会,并通过“文旅大屏+展台”的形式,全面直观地向外界展现美团门票、酒店、民宿等业务在目的地旅游市场振兴方面提供的...

一个好的网站seo优化公司是什么样?哪种seo优化公司能帮企业盈利。

一个好的网站seo优化公司是什么样?哪种seo优化公司能帮企业盈利。

随着社会的发展,我们已经进入了互联网时代。如果我们想,我们必须加入互联网。那么如何选择一家可靠又好的,小编给你一些科普经验,一起看看吧。 现在越来越多的网络公司都在从事网站建设和SEO网站优化项目。市场上优化公司越来越多,技术也参差不齐。如果你已经学会了SEO,你可以为其他人做一些简...

APP推广效果排名前十渠道在这里!

APP推广效果排名前十渠道在这里!

相信不少负责APP推广的同学会很困惑iOS怎么买量?老板给了一笔预算,要求采买一些优质iOS流量。但是投放结果总不如意。哪些渠道可以低成本采买 iOS流量又可以回收快速?如何更好的满足老板的KPI?今天这篇文章可算是血泪教训了,文章详述各个渠道的买量效果评估,赶紧来涨知识! 笔者有幸参与...

小编分享小编SEO:认真对待存在问题更可靠更有效SEO优化。

小编分享小编SEO:认真对待存在问题更可靠更有效SEO优化。

我们首先要知道,seo到底最讨厌,或者说最忌讳的是什么?首先就是,买空间的问题。千万不要和作弊网站在同一台服务器上。内容要有一定的原创性,这是大家都必须知道的一个问题,如果内容缺乏原创性,就是优化的一大忌讳。还有就是内容网站的主题,或者说不相符,网页的标题频繁的变动,页面全动画,没有所谓的静态。...

一篇文章让你快速了解运营的各个方面(入门篇)

鸟哥笔记在本周四发起了一个征集读书笔记的活动,本文为怪木西西读《从零开始做运营》入门篇的读书笔记,算是对本书的一个整体梗概,如果你有好的读书笔记也可以投稿鸟哥笔记(投稿邮箱:tougao@appcpx.com) (一)本书作者 张亮,互联网从业者,知乎互联网领域...

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

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