老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

一篇文章幫你了解promise與setTimeout的執(zhí)行順序

這篇文章主要介紹一篇文章幫你了解promise與setTimeout的執(zhí)行順序,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

成都創(chuàng)新互聯(lián)公司是一家專業(yè)提供淄博企業(yè)網(wǎng)站建設(shè),專注與做網(wǎng)站、網(wǎng)站建設(shè)、HTML5、小程序制作等業(yè)務(wù)。10年已為淄博眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進(jìn)行中。

有一次在面試題中有做到promise與setTimeout的執(zhí)行順序,當(dāng)時(shí)有點(diǎn)懵,執(zhí)行順序還是弄錯(cuò)了一點(diǎn)點(diǎn),這里記錄下

1.輸出

setTimeout(function() {
console.log(111)
}, 0);
setTimeout(function() {
console.log(333)
}, 1000);
new Promise(function(resolve){
console.log(444);
resolve();
console.log(555);
})。then(function(){
console.log(666);
});
console.log(777);
async function test1() {
console.log("test1");
await test2();
console.log("test1 last");
}
async function test2() {
console.log("test2");
}
test1();

輸出結(jié)果

一篇文章幫你了解promise與setTimeout的執(zhí)行順序

2.個(gè)人理解

首先執(zhí)行同步代碼,然后以事件輪詢的方式執(zhí)行異步代碼

promise中的異步體現(xiàn)在。then()和。catch()中

而promise中的function里的是同步代碼

上面的代碼是先執(zhí)行promise里的同步代碼,然后執(zhí)行腳本里本身的同步代碼

async無(wú)論方法是同步還是異步都可以用async關(guān)鍵字來(lái)進(jìn)行標(biāo)識(shí)

因?yàn)橛胊sync標(biāo)識(shí)只是顯示表明在該方法內(nèi),可能會(huì)用到await關(guān)鍵字使其變?yōu)楫惒椒椒ǎ覍⒃摦惒椒椒ㄟM(jìn)行了明確的劃分,只有用了await關(guān)鍵字時(shí)才是異步操作,其余一并為同步操作

同 Generator 函數(shù)一樣,async 函數(shù)返回一個(gè) Promise 對(duì)象,可以使用 then 方法添加回調(diào)函數(shù)

當(dāng)函數(shù)執(zhí)行的時(shí)候,一旦遇到 await 就會(huì)先返回,等到觸發(fā)的異步操作完成,再接著執(zhí)行函數(shù)體內(nèi)后面的語(yǔ)句

await 命令后面的 Promise 對(duì)象,運(yùn)行結(jié)果可能是 rejected,所以最好把 await 命令放在 try…catch 代碼塊中

3.其他

在網(wǎng)上還找到了一些資料參考了這篇文章的一些內(nèi)容 參考文章

setImmediate(function(){
console.log(1);
},0);
setTimeout(function(){
console.log(2);
},0);
new Promise(function(resolve){
console.log(3);
resolve();
console.log(4);
})。then(function(){
console.log(5);
});
console.log(6);
process.nextTick(function(){
console.log(7);
});
console.log(8);

輸出結(jié)果: 3 4 6 8 7 5 2 1

macro-task: script (整體代碼),setTimeout, setInterval, setImmediate, I/O, UI rendering.
micro-task: process.nextTick, Promise(原生),Object.observe,MutationObserver

第一步。 script整體代碼被執(zhí)行,執(zhí)行過(guò)程為

創(chuàng)建setImmediate macro-task
創(chuàng)建setTimeout macro-task
創(chuàng)建micro-task Promise.then 的回調(diào),并執(zhí)行script console.log(3); resolve(); console.log(4); 此時(shí)輸出3和4,雖然resolve調(diào)用了,執(zhí)行了但是整體代碼還沒(méi)執(zhí)行完,無(wú)法進(jìn)入Promise.then 流程。
console.log(6)輸出6
process.nextTick 創(chuàng)建micro-task
console.log(8) 輸出8

第一個(gè)過(guò)程過(guò)后,已經(jīng)輸出了3 4 6 8

第二步。 由于其他micro-task 的 優(yōu)先級(jí)高于macro-task。

此時(shí)micro-task 中有兩個(gè)任務(wù)按照優(yōu)先級(jí)process.nextTick 高于 Promise,所以先輸出7,再輸出5

第三步,micro-task 任務(wù)列表已經(jīng)執(zhí)行完畢,家下來(lái)執(zhí)行macro-task. 由于setTimeout的優(yōu)先級(jí)高于setIImmediate,所以先輸出2,再輸出1。

優(yōu)先級(jí): promise.Trick()>promise的回調(diào)>setTimeout>setImmediate

以上是“一篇文章幫你了解promise與setTimeout的執(zhí)行順序”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


新聞名稱:一篇文章幫你了解promise與setTimeout的執(zhí)行順序
網(wǎng)址分享:http://www.xueling.net.cn/article/geepdo.html

其他資訊

在線咨詢
服務(wù)熱線
服務(wù)熱線:028-86922220
TOP
主站蜘蛛池模板: 色哟哟日韩精品 | 黄色毛片免费 | 4HU四虎永久免费地址WW416 | H无码精品视频在线观看网站 | 大地资源高清在线观看免费新浪 | 亚洲精品日韩综合观看成人91 | 国产高潮白浆黑丝 | 国产古装三级在线 | 无套内谢孕妇毛片免费看看 | 中文字幕在线观看www | 国产网站色 | 极品尤物一区 | 黄色a级片免费看 | 免费观看作爱视频网站 | 国产日本中文久久 | 亚洲熟女精品中文字幕 | 成人免费看的A级毛片 | 浪货跪下给我好好含着羞辱调教 | 蝌蚪成人网 | 国产精品呻吟 | 国产精品不卡一区二区三区在线观看 | 成人亚洲综合 | 亚洲影院丰满少妇中文字幕无码 | 六度影院鲁鲁片在线看 | 性刺激的大陆三级视频 | 亚洲丰满熟女一区二区v | 精品国产亚洲AV麻豆 | 国产黄色a级毛片 | 日韩一区二区观看 | 成人妇女免费播放久久久 | 国产精品成人AAAA网站女吊丝 | 麻豆免费观看网站 | 久久99最新地址 | 噜噜噜噜噜在线视频 | 妖精森林的救世主动漫在线观看 | 亚洲国产精品自拍 | 久久激情日本aⅴ | 久久日韩粉嫩一区二区三区 | 国产精品久久久久影院色老大 | 一区二区三区四区不卡 | 国内精品久久久久久久小说 |