setTimeout、Promise暇藏、Async/Await 的區(qū)別

1蜜笤、JS是單線(xiàn)程語(yǔ)言,包括同步任務(wù)盐碱、異步任務(wù)把兔,異步任務(wù)又包括宏觀任務(wù)和微觀任務(wù)

2、執(zhí)行順序:同步任務(wù)——>微觀任務(wù)——>宏觀任務(wù)

3瓮顽、宏觀任務(wù)的方法有:script(整體代碼)县好、setTimeout、setInterval暖混、I/O缕贡、UI交互事件、postMessage拣播、MessageChannel晾咪、setImmediate(Node.js 環(huán)境)

4、微觀任務(wù)的方法有:Promise.then贮配、MutaionObserver谍倦、process.nextTick(Node.js 環(huán)境),async/await實(shí)際上是promise+generator的語(yǔ)法糖牧嫉,也就是promise剂跟,也就是微觀任務(wù)

1. setTimeout

console.log('script start') //1. 打印 script start
setTimeout(function(){
    console.log('settimeout')   // 4. 打印 settimeout
})  // 2. 調(diào)用 setTimeout 函數(shù),并定義其完成后執(zhí)行的回調(diào)函數(shù)
console.log('script end')   //3. 打印 script start
// 輸出順序:script start->script end->settimeout

2. Promise

console.log('script start')
let promise1 = new Promise(function (resolve) {
    console.log('promise1')
    resolve()
    console.log('promise1 end')
}).then(function () {
    console.log('promise2')
})
setTimeout(function(){
    console.log('settimeout')
})
console.log('script end')
// 輸出順序: script start->promise1->promise1 end->script end->promise2->settimeout

3. async/await

async function async1(){
   console.log('async1 start');
    await async2();
    console.log('async1 end')
}
async function async2(){
    console.log('async2')
}
 
console.log('script start');
async1();
console.log('script end')
 
// 輸出順序:script start->async1 start->async2->script end->async1 end

執(zhí)行先后順序 setTimeout酣藻、Promise曹洽、Async/Await 對(duì)比

async function async1() {
    console.log('async1 start');
    await async2();
    console.log('async1 end');
}
async function async2() {
    console.log('async2');
}

console.log('start');
setTimeout(() => {
    console.log('setTimeout');
}, 0);
async1();
new Promise(resolve => {
    console.log('promise1');
    resolve();
}).then(() => {
    console.log('promise2');
})
console.log('end');

運(yùn)行結(jié)果

start
async1 start
async2
promise1
end
promise2
async1 end
setTimeout

調(diào)用順序問(wèn)題解析:

async 會(huì)定義一個(gè)返回 AsyncFunction 對(duì)象的異步函數(shù)。即以 async 聲明的函數(shù)辽剧,會(huì)隱式地返回一個(gè) Promise 對(duì)象送淆。當(dāng)這個(gè) async 函數(shù)返回一個(gè)值時(shí),Promise 的 resolve 方法會(huì)負(fù)責(zé)傳遞這個(gè)值怕轿;當(dāng) async 函數(shù)拋出異常時(shí)偷崩,Promise 的 reject 方法也會(huì)傳遞這個(gè)異常值辟拷。
await 操作符用于等待一個(gè) Promise 對(duì)象。它返回 Promise 對(duì)象的處理結(jié)果阐斜。如果等待的不是 Promise 對(duì)象衫冻,則返回該值本身。
注意:
await 只能在異步函數(shù) async function 中使用谒出。
如果你希望并行等待兩個(gè)或者是更多的 Promise 對(duì)象隅俘,你必須使用Promise.then,而不是await笤喳。

隊(duì)列任務(wù)優(yōu)先級(jí):promise.Trick() > promise的回調(diào) > setTimeout > setImmediate

因此上述代碼可以理解成:(部分用語(yǔ)可能不準(zhǔn)確)

在同步執(zhí)行階段:
async1執(zhí)行到await async2()時(shí)为居,sync2()返回一個(gè)Promise, 其resolve放入到回調(diào)隊(duì)列中,跳出async1杀狡,執(zhí)行new promise的resolve時(shí)蒙畴,該resolve也會(huì)被放入回調(diào)隊(duì)列中。然后執(zhí)行到console.log('end');呜象,此時(shí)同步執(zhí)行結(jié)束膳凝。

重點(diǎn)(執(zhí)行回調(diào)隊(duì)列):
此時(shí)async2()返回的 Promise的resolve會(huì)被執(zhí)行,即執(zhí)行await async2()董朝,此時(shí)await的Promise的resolve會(huì)被放入到新回調(diào)隊(duì)列鸠项。此時(shí)原回調(diào)隊(duì)列中new promise的resolve會(huì)被執(zhí)行,promise2字符被打印子姜,原回調(diào)隊(duì)列執(zhí)行完畢祟绊。

執(zhí)行新回調(diào)隊(duì)列:
await的Promise的resolve被執(zhí)行,console.log('async1 end')執(zhí)行哥捕。async1()返回的Promise的resolve會(huì)被放入到新回調(diào)隊(duì)列牧抽。

所有回調(diào)隊(duì)列執(zhí)行完畢,setTimeout執(zhí)行遥赚。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末扬舒,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子凫佛,更是在濱河造成了極大的恐慌讲坎,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,627評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件愧薛,死亡現(xiàn)場(chǎng)離奇詭異晨炕,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)毫炉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,180評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)瓮栗,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事费奸∶旨ぃ” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 169,346評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵愿阐,是天一觀的道長(zhǎng)微服。 經(jīng)常有香客問(wèn)我,道長(zhǎng)换况,這世上最難降的妖魔是什么职辨? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 60,097評(píng)論 1 300
  • 正文 為了忘掉前任盗蟆,我火速辦了婚禮戈二,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘喳资。我一直安慰自己觉吭,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,100評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布仆邓。 她就那樣靜靜地躺著鲜滩,像睡著了一般。 火紅的嫁衣襯著肌膚如雪节值。 梳的紋絲不亂的頭發(fā)上徙硅,一...
    開(kāi)封第一講書(shū)人閱讀 52,696評(píng)論 1 312
  • 那天,我揣著相機(jī)與錄音搞疗,去河邊找鬼嗓蘑。 笑死,一個(gè)胖子當(dāng)著我的面吹牛匿乃,可吹牛的內(nèi)容都是我干的桩皿。 我是一名探鬼主播,決...
    沈念sama閱讀 41,165評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼幢炸,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼泄隔!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起宛徊,我...
    開(kāi)封第一講書(shū)人閱讀 40,108評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤佛嬉,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后闸天,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體暖呕,經(jīng)...
    沈念sama閱讀 46,646評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,709評(píng)論 3 342
  • 正文 我和宋清朗相戀三年号枕,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了缰揪。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,861評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖钝腺,靈堂內(nèi)的尸體忽然破棺而出抛姑,到底是詐尸還是另有隱情,我是刑警寧澤艳狐,帶...
    沈念sama閱讀 36,527評(píng)論 5 351
  • 正文 年R本政府宣布定硝,位于F島的核電站,受9級(jí)特大地震影響毫目,放射性物質(zhì)發(fā)生泄漏蔬啡。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,196評(píng)論 3 336
  • 文/蒙蒙 一镀虐、第九天 我趴在偏房一處隱蔽的房頂上張望箱蟆。 院中可真熱鬧,春花似錦刮便、人聲如沸空猜。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,698評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)辈毯。三九已至,卻和暖如春搜贤,著一層夾襖步出監(jiān)牢的瞬間谆沃,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,804評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工仪芒, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留唁影,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,287評(píng)論 3 379
  • 正文 我出身青樓桌硫,卻偏偏與公主長(zhǎng)得像夭咬,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子铆隘,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,860評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容