教育行業(yè)A股IPO第一股(股票代碼 003032)

全國咨詢/投訴熱線:400-618-4000

JavaScript事件循環(huán):同步任務(wù)和異步任務(wù)

更新時(shí)間:2021年10月07日16時(shí)00分 來源:傳智教育 瀏覽次數(shù):

好口碑IT培訓(xùn)

JavaScript 是一門單線程執(zhí)行的編程語言。也就是說,同一時(shí)間只能做一件事情。如果前一個(gè)任務(wù)非常耗時(shí),則后續(xù)的任務(wù)就不得不一直等待,從而導(dǎo)致程序假死的問題。所以為了防止某個(gè)耗時(shí)任務(wù)導(dǎo)致程序假死的問題,JavaScript 把待執(zhí)行的任務(wù)分為了兩類:
①同步任務(wù)(synchronous)
又叫做非耗時(shí)任務(wù),指的是在主線程上排隊(duì)執(zhí)行的那些任務(wù)
只有前一個(gè)任務(wù)執(zhí)行完畢,才能執(zhí)行后一個(gè)任務(wù)
②異步任務(wù)(asynchronous)
又叫做耗時(shí)任務(wù),異步任務(wù)由JavaScript 委托給宿主環(huán)境進(jìn)行執(zhí)行
當(dāng)異步任務(wù)執(zhí)行完成后,會(huì)通知JavaScript 主線程執(zhí)行異步任務(wù)的回調(diào)函數(shù)

同步任務(wù)和異步任務(wù)的執(zhí)行過程:

同步任務(wù)和異步任務(wù)的執(zhí)行過程

①同步任務(wù)由JavaScript 主線程次序執(zhí)行

②異步任務(wù)委托給宿主環(huán)境執(zhí)行

③已完成的異步任務(wù)對(duì)應(yīng)的回調(diào)函數(shù),會(huì)被加入到任務(wù)隊(duì)列中等待執(zhí)行

④JavaScript 主線程的執(zhí)行棧被清空后,會(huì)讀取任務(wù)隊(duì)列中的回調(diào)函數(shù),次序執(zhí)行

⑤JavaScript 主線程不斷重復(fù)上面的第4 步

JavaScript 主線程從“任務(wù)隊(duì)列”中讀取異步任務(wù)的回調(diào)函數(shù),放到執(zhí)行棧中依次執(zhí)行。這個(gè)過程是循環(huán)不斷的,所以整個(gè)的這種運(yùn)行機(jī)制又稱為EventLoop(事件循環(huán))。

同步任務(wù)和異步任務(wù)

import thenFs from ' then-fs '

console 
log('A')
thenFs. readFile(' ./files/1.txt', 'utf8' ). then(dataStr => {

console.log('B')
 })
setTimeout(( ) => {
console. log('C' )
},0)
console.log( 'D')

正確的輸出結(jié)果:ADCB。其中:

A 和D 屬于同步任務(wù)。會(huì)根據(jù)代碼的先后順序依次被執(zhí)行

C 和B 屬于異步任務(wù)。它們的回調(diào)函數(shù)會(huì)被加入到任務(wù)隊(duì)列中,等待主線程空閑時(shí)再執(zhí)行



猜你喜歡:

JavaScript九九乘法表加邊框如何實(shí)現(xiàn)?

5款常用JavaScript開發(fā)工具推薦

使用JavaScript變量需要注意哪些語法細(xì)節(jié)?

傳智教育web前端與移動(dòng)開發(fā)培訓(xùn)班

0 分享到:
和我們?cè)诰€交談!