




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第JS異步的執(zhí)行順序分析1.js的執(zhí)行順序,先同步后異步2.異步中任務(wù)隊(duì)列的執(zhí)行順序:先微任務(wù)microtask隊(duì)列,再宏任務(wù)macrotask隊(duì)列3.調(diào)用Promise中的resolve,reject屬于微任務(wù)隊(duì)列,setTimeout屬于宏任務(wù)隊(duì)列
注意以上都是隊(duì)列,先進(jìn)先出。
微任務(wù)包括`process.nextTick`,`promise`,`MutationObserver`。
宏任務(wù)包括`script`,`setTimeout`,`setInterval`,`setImmediate`,`I/O`,`UIrendering`。
在node環(huán)境下,process.nextTick的優(yōu)先級(jí)高于Promise,也就是可以簡(jiǎn)單理解為:在宏任務(wù)結(jié)束后會(huì)先執(zhí)行微任務(wù)隊(duì)列中的nextTickQueue部分,然后才會(huì)執(zhí)行微任務(wù)中的Promise部分。
javascript事件機(jī)制
console.log('scriptstart')
asyncfunctionasync1(){
awaitasync2()
console.log('async1end')
asyncfunctionasync2(){
console.log('async2end')
async1()
setTimeout(function(){
console.log('setTimeout')
},0)
newPromise(resolve={
console.log('Promise')
resolve()
.then(function(){
console.log('promise1')
.then(function(){
console.log('promise2')
console.log('scriptend')
執(zhí)行結(jié)果?
分析:
首先執(zhí)行同步代碼:
1.首先執(zhí)行console.log(scriptstart)2.執(zhí)行async1()的時(shí)候,馬上執(zhí)行了async2函數(shù):console.log(async2end)3.順序執(zhí)行newPromise()中的同步函數(shù):console.log(Promise)4.最后執(zhí)行console.log(scriptend)。
上面是同步執(zhí)行的代碼,然后看剩下的異步執(zhí)行的代碼:
首先,setTimeout是宏觀任務(wù),排除到最后,剩下微觀任務(wù):
asyncfunctionasync1(){
awaitasync2()
console.log('async1end')
newPromise(resolve={
resolve()
.then(function(){
console.log('promise1')
.then(function(){
console.log('promise2')
})
5.然后根據(jù)先入先出的對(duì)列方式,先執(zhí)行awaitasync2()后面阻礙的函數(shù)console.log(async1end)6.執(zhí)行promise的resolve函數(shù)
newPromise(resolve={
resolve()
})
也就是接下來(lái)的兩個(gè)then:console.log(promise1)----console.log(promise2);
7.最后執(zhí)行的是setTimeout函數(shù)console.log(setTimeout);
綜上所述,以上代碼執(zhí)行的順序是:
1.scriptstart2.async2end3.Promise4.scriptend5.async1end6.promise17.promise28.setTimeout
(function(){
setTimeout(()={
console.log(0);
newPromise(resolve={
console.log(1);
setTimeout(()={
resolve();
Promise.resolve().then(()=console.log(2));
console.log(3);
Promise.resolve().then(()=console.log(4));
}).then(()={
console.log(5);
Promise.resolve().then(()=console.log(8));
setTimeout(()=console.log(6));
console.log(7);
})();
1.同樣先執(zhí)行同步代碼,且先把setTimeout去掉:
newPromise(resolve={
console.log(1);
Promise.resolve().then(()=console.log(4));//微觀任務(wù)
}).then(()={//then函數(shù)是執(zhí)行對(duì)應(yīng)的resolve的時(shí)候才執(zhí)行的
console.log(5);
Promise.resolve().then(()=console.log(8));//微觀任務(wù)
});console.log(7);
可以看出先執(zhí)行:console.log(1);console.log(7);
2.執(zhí)行微任務(wù)Promise.resolve().then(()=console.log(4));
代碼變成了:
(function(){
setTimeout(()={
console.log(0);
newPromise(resolve={
setTimeout(()={
resolve();
Promise.resolve().then(()=console.log(2));
console.log(3);
}).then(()={
console.log(5);
Promise.resolve().then(()=console.log(8));//這句是多加的
setTimeout(()=console.log(6));
})();
只剩下宏觀任務(wù)(微觀任務(wù)在宏觀任務(wù)里,也就是宏觀任務(wù)外面不在有微觀任務(wù)了)
3.執(zhí)行console.log(0);4.再執(zhí)行newPromise中的setTimeout,先執(zhí)行里面的同步函數(shù):console.log(3)5.再執(zhí)行上面的resolve,對(duì)應(yīng)的是下面的then函數(shù):
then(()={
console.log(5);
Promise.resolve().then(()=console.log(8));//這句是多加的
setTimeout(()=console.log(6));
}
所以先執(zhí)行console.log(5);
剩下的都是微觀任務(wù)和宏觀任務(wù),先看微觀任務(wù):
newPromise(resolve={
resolve();
Promise.resolve().then(()=console.log(2));
}).then(()={
Promise.resolve().then(()=console.log(8));
setTimeout(()=console.log(6));
});
所以根據(jù)隊(duì)列中的微觀任務(wù)順序先執(zhí)行:console.log(2),在執(zhí)行then中的console.log(8);
最后再執(zhí)行console.log(6)
綜上所述,結(jié)果為
1/7/4/0/3/5/2/8/6
(function(){
setTimeout(()={
console.log(0);
newPromise(resolve={
console.log(1);
setTimeout(()={
resolve();
Promise.resolve().then(()={
console.log(2);
setTimeout(()=console.log(3));
Promise.resolve().then(()=console.log(4));
Promise.resolve().then(()=console.log(5));
}).then(()={
console.log(6);
Promise.resolve().then(()=console.log(7));
setTimeout(()=console.log(8));
console.log(9);
})();
解釋如下:【同步異步;微任務(wù)宏任務(wù)】第一步:打印出1、9;如圖
圖a
由圖a中的任務(wù)隊(duì)列可知:
第二步:執(zhí)行微任務(wù)3,打印出5;
第三步:執(zhí)行宏任務(wù)1,打印出0,
第四步:開(kāi)始執(zhí)行宏任務(wù)2;如圖:
圖b
第五步:由圖b中的任務(wù)隊(duì)列可知,執(zhí)行微任務(wù)4,打印出6,如圖:
圖c
第六步:由圖c中的
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025內(nèi)蒙古鄂爾多斯市東方控股集團(tuán)有限公司校園招聘15人考前自測(cè)高頻考點(diǎn)模擬試題附答案詳解(突破訓(xùn)練)
- 2025年中國(guó)花卉種植箱行業(yè)市場(chǎng)分析及投資價(jià)值評(píng)估前景預(yù)測(cè)報(bào)告
- 2025貴州都勻市直部門(mén)(含所屬事業(yè)單位)考調(diào)工作人員35人考前自測(cè)高頻考點(diǎn)模擬試題及1套參考答案詳解
- 2025年阜陽(yáng)民生醫(yī)院招聘20人考前自測(cè)高頻考點(diǎn)模擬試題附答案詳解(模擬題)
- 2025安順市平壩區(qū)美農(nóng)科技有限公司招聘模擬試卷及參考答案詳解
- 2025廣西壯族自治區(qū)體育局機(jī)關(guān)服務(wù)中心招聘編外人員2人模擬試卷完整答案詳解
- 2025內(nèi)蒙古赤峰市紅山區(qū)“綠色通道”引進(jìn)教師94人模擬試卷及參考答案詳解1套
- 【教師招聘】2025年九江經(jīng)濟(jì)技術(shù)開(kāi)發(fā)區(qū)中心幼兒園公開(kāi)招聘頂崗教師考前自測(cè)高頻考點(diǎn)模擬試題附答案詳解
- 2025年攀枝花市科學(xué)技術(shù)局所屬事業(yè)單位春季人才引進(jìn)考核招聘模擬試卷及答案詳解(全優(yōu))
- 2025春季國(guó)家電投廣東公司校園招聘考前自測(cè)高頻考點(diǎn)模擬試題及答案詳解(名校卷)
- 信創(chuàng)的基礎(chǔ)知識(shí)培訓(xùn)課件
- 2024年江蘇省常州市武進(jìn)區(qū)中考三模道德與法治試題
- 臨時(shí)工工傷私了協(xié)議書(shū)
- 人工造林項(xiàng)目投標(biāo)方案(技術(shù)方案)
- 微生物與單細(xì)胞蛋白
- 江蘇開(kāi)放大學(xué)2024年春《公文寫(xiě)作與處理 050008》第一次作業(yè)(占平時(shí)成績(jī)的20%)參考答案
- 冠心病PCI術(shù)后康復(fù)策略
- 通勤車(chē)租賃投標(biāo)方案(技術(shù)標(biāo))
- 脲的合成方法總結(jié)
- 《田螺姑娘》兒童故事ppt課件(圖文演講)
- 機(jī)械設(shè)備月租賃結(jié)算單
評(píng)論
0/150
提交評(píng)論