电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

用幾道面試題來看JavaScript執行機制

瀏覽:88日期:2023-09-30 10:00:43
前面的話

根據JavaScript的運行環境,鎖定它為單線程,任務需要排隊執行,如果網站資源比較大,這樣會導致瀏覽器加載會很慢,但實際上并沒有,大家肯定立刻想到了同步和異步。

所謂的同步和異步也是在排隊,只是排隊的地方不同。

同步和異步

同步任務進入主線程排隊,異步任務進入事件隊列中排隊

同步任務和異步任務進入到不同的隊列中,也就是上面講的在不同地方排隊。

同步任務進入主線程,異步任務進入事件隊列,主線程任務執行完畢,事件隊列中有等待執行的任務進入主線程執行,直到事件隊列中任務全部執行完畢。

開胃菜

console.log(’a’)setTimeout(function(){ console.log(’b’)}, 200)setTimeout(function(){ console.log(’c’)}, 0)console.log(’d’)

a d c b

從上到下,該進入主線程的進入主線程,該進入事件隊列的進入事件隊列。

那么主線程中存在console.log(’a’)和console.log(’d’),定時器setTimeout延遲一段時間執行,顧名思義異步任務進入事件隊列中,等待主線程任務執行完畢,再進入主線程執行。

定時器的延遲時間為0并不是立刻執行,只是代表相比于其他定時器更早的進入主線程中執行。

加一盤

for(var i = 0; i < 10; i++) { setTimeout(function() {console.log(i) }, 1000)}

結果:十個10

每次for循環遇到setTimeout將其放入事件隊列中等待執行,直到全部循環結束,i作為全局變量當循環結束后i = 10,再來執行setTimeout時i的值已經為10, 結果為十個10。

將var改為let,變量作用域不同,let作用在當前循環中,所以進入事件隊列的定時器每次的i不同,最后打印結果會是 0 1 2...9。

宏任務 微任務

除了經常說的同步任務和異步任務之外,更可分為宏任務,微任務

主要宏任務:整段腳本scriptsetTimeoutsetTimeout...

主要微任務:promise.then...

執行流程:

1.整段腳本script作為宏任務開始執行

2.遇到微任務將其推入微任務隊列,宏任務推入宏任務隊列

3.宏任務執行完畢,檢查有沒有可執行的微任務

4.發現有可執行的微任務,將所有微任務執行完畢

5.開始新的宏任務,反復如此直到所有任務執行完畢

來一盤Promise

const p = new Promise(resolve => { console.log(’a’) resolve() console.log(’b’)})p.then(() => { console.log(’c’)})console.log(’d’)

結果:a b d c

1.整段script進入宏任務隊列開始執行

2.promise創建立即執行,打印ab

3.遇到promise.then進入微任務隊列

4.遇到console.log(’d’)打印d

5.整段代碼作為宏任務執行完畢,有可執行的微任務,開始執行微任務,打印c。

setTimeout(function(){ console.log(’setTimeout’)}, 0)const p = new Promise(resolve => { console.log(’a’) resolve() console.log(’b’)})p.then(() => { console.log(’c’)})console.log(’d’)

結果:a b d c setTimeout

1.setTimeout進入宏任務隊列

2.promise創建立即執行,打印ab

3.遇到promise.then進入微任務隊列

4.遇到console.log(’d’)打印d

5.有可執行的微任務,打印c

6.微任務執行完畢,開始執行新的宏任務,setTimeout開始執行,打印setTimeout

setTimeout(function(){ console.log(’setTimeout’)}, 0)const p = new Promise(resolve => { console.log(’a’) resolve() console.log(’b’)})p.then(() => { console.log(’c’) setTimeout(function(){console.log(’then中的setTimeout’) }, 0)})console.log(’d’)

結果:a b d c setTimeout then中的setTimeout

1.同上

2.執行微任務打印c,遇到setTimeout將其推入宏任務隊列中

3.定時器延遲時間相同,開始按照順序執行宏任務,分別打印setTimeoutthen中的setTimeout

再加點定時器

console.log(’a’);new Promise(resolve => { console.log(’b’) resolve()}).then(() => { console.log(’c’) setTimeout(() => { console.log(’d’) }, 0)})setTimeout(() => { console.log(’e’) new Promise(resolve => {console.log(’f’)resolve() }).then(() => {console.log(’g’) })}, 100)setTimeout(() => { console.log(’h’) new Promise(resolve => {resolve() }).then(() => {console.log(’i’) }) console.log(’j’)}, 0)

結果:a b c h j i d e f g

1.打印a

2.promise立即執行,打印b

3.promise.then推入微任務隊列

4.setTimeout推入宏任務隊列

5.整段代碼執行完畢,開始執行微任務,打印c,遇到setTimeout推入宏任務隊列排隊等待執行

6.沒有可執行的微任務開始執行宏任務,定時器按照延遲時間排隊執行

7.打印h j,promise.then推入微任務隊列有

8.可執行的微任務,打印i,繼續執行宏任務,打印d

9.執行延遲為100的宏任務,打印e f,執行微任務打印g,所有任務執行完畢

簡單測試

console.log(’start’)a().then(() => { console.log(’a_then’)})console.log(’end’)function a() { console.log(’a_function’) return b().then((res) => { console.log(’res’, res) console.log(’b_then’) return Promise.resolve(’a方法的返回值’) })}function b() { console.log(’b_function’) return Promise.resolve(’返回值’)}

結果:start a_function b_function end res 返回值 b_then a_then

根據上面例子的流程講解來思考這個,加深理解

總結 JavaScript單線程,任務需要排隊執行 同步任務進入主線程排隊,異步任務進入事件隊列排隊等待被推入主線程執 行定時器的延遲時間為0并不是立刻執行,只是代表相比于其他定時器更早的被執行 以宏任務和微任務進一步理解js執行機制 整段代碼作為宏任務開始執行,執行過程中宏任務和微任務進入相應的隊列中 整段代碼執行結束,看微任務隊列中是否有任務等待執行,如果有則執行所有的微任務,直到微任務隊列中的任務執行完畢,如果沒有則繼續 執行新的宏任務執行新的宏任務,凡是在執行宏任務過程中遇到微任務都將其推入微任務隊列中執行 反復如此直到所有任務全部執行完畢

以上就是用幾道面試題來看JavaScript執行機制的詳細內容,更多關于JavaScript執行機制的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 心肺复苏模拟人|医学模型|急救护理模型|医学教学模型上海康人医学仪器设备有限公司 | 代写标书-专业代做标书-商业计划书代写「深圳卓越创兴公司」 | 空心明胶胶囊|植物胶囊|清真胶囊|浙江绿键胶囊有限公司欢迎您! | 头条搜索极速版下载安装免费新版,头条搜索极速版邀请码怎么填写? - 欧远全 | 化妆品加工厂-化妆品加工-化妆品代加工-面膜加工-广东欧泉生化科技有限公司 | 防勒索软件_数据防泄密_Trellix(原McAfee)核心代理商_Trellix(原Fireeye)售后-广州文智信息科技有限公司 | ETFE膜结构_PTFE膜结构_空间钢结构_膜结构_张拉膜_浙江萬豪空间结构集团有限公司 | 道达尔润滑油-食品级润滑油-道达尔导热油-合成导热油,深圳道达尔代理商合-深圳浩方正大官网 | 包塑软管|金属软管|包塑金属软管-闵彬管业 | 油冷式_微型_TDY电动滚筒_外装_外置式电动滚筒厂家-淄博秉泓机械有限公司 | 浩方智通 - 防关联浏览器 - 跨境电商浏览器 - 云雀浏览器 | 海尔生物医疗四川代理商,海尔低温冰箱四川销售-成都壹科医疗器械有限公司 | 拉力机-拉力试验机-万能试验机-电子拉力机-拉伸试验机-剥离强度试验机-苏州皖仪实验仪器有限公司 | 重庆小面培训_重庆小面技术培训学习班哪家好【终身免费复学】 | 蜂窝块状沸石分子筛-吸附脱硫分子筛-萍乡市捷龙环保科技有限公司 | 重庆波纹管|重庆钢带管|重庆塑钢管|重庆联进管道有限公司 | 玻璃钢型材-玻璃钢风管-玻璃钢管道,生产厂家-[江苏欧升玻璃钢制造有限公司] | 广域铭岛Geega(际嘉)工业互联网平台-以数字科技引领行业跃迁 | 国产离子色谱仪,红外分光测油仪,自动烟尘烟气测试仪-青岛埃仑通用科技有限公司 | 广西绿桂涂料--承接隔热涂料、隔音涂料、真石漆、多彩仿石漆等涂料工程双包施工 | 苏州同创电子有限公司 - 四探针测试仪源头厂家 | 希望影视-高清影视vip热播电影电视剧免费在线抢先看 | 呼末二氧化碳|ETCO2模块采样管_气体干燥管_气体过滤器-湖南纳雄医疗器械有限公司 | 钢格板_钢格栅_格栅板_钢格栅板 - 安平县鑫拓钢格栅板厂家 | 聚丙烯酰胺PAM-聚合氯化铝PAC-絮凝剂-河南博旭环保科技有限公司 巨野电机维修-水泵维修-巨野县飞宇机电维修有限公司 | 棉柔巾代加工_洗脸巾oem_一次性毛巾_浴巾生产厂家-杭州禾壹卫品科技有限公司 | 合金耐磨锤头_破碎机锤头_郑州市德勤建材有限公司 | 尼龙PA610树脂,尼龙PA612树脂,尼龙PA1010树脂,透明尼龙-谷骐科技【官网】 | 蓝鹏测控平台 - 智慧车间系统 - 车间生产数据采集与分析系统 | 螺杆泵_中成泵业| 雾度仪_雾度计_透光率雾度仪价格-三恩时(3nh)光电雾度仪厂家 | 贵州水玻璃_-贵阳花溪闽兴水玻璃厂| 福州甲醛检测-福建室内空气检测_环境检测_水质检测-福建中凯检测技术有限公司 | 钛板_钛管_钛棒_钛盘管-无锡市盛钛科技有限公司 | 刺绳_刀片刺网_刺丝滚笼_不锈钢刺绳生产厂家_安平县浩荣金属丝网制品有限公司-安平县浩荣金属丝网制品有限公司 | 网站制作优化_网站SEO推广解决方案-无锡首宸信息科技公司 | 油漆辅料厂家_阴阳脚线_艺术漆厂家_内外墙涂料施工_乳胶漆专用防霉腻子粉_轻质粉刷石膏-魔法涂涂 | 上海噪音治理公司-专业隔音降噪公司-中广通环保 | 双工位钻铣攻牙机-转换工作台钻攻中心-钻铣攻牙机一体机-浙江利硕自动化设备有限公司 | 碳化硅,氮化硅,冰晶石,绢云母,氟化铝,白刚玉,棕刚玉,石墨,铝粉,铁粉,金属硅粉,金属铝粉,氧化铝粉,硅微粉,蓝晶石,红柱石,莫来石,粉煤灰,三聚磷酸钠,六偏磷酸钠,硫酸镁-皓泉新材料 | 广州二手电缆线回收,旧电缆回收,广州铜线回收-广东益福电缆线回收公司 |