什么是宏任务和微任务
JavaScript把异步任务又做了进一步的划分,异步任务又分为两类,分别是:
- 宏任务(macrotask)
- 异步的Ajax请求
- setTimeout、setInterval
- 文件操作
- 其它宏任务
- 微任务(microtask)
- Promise.then、.catch和finally
- process.nextTick
- 其它微任务
宏任务与微任务的执行顺序
每一个宏任务执行完之后,都会检查是否存在待执行的微任务,如果有,则执行完所有的微任务之后,再继续执行下一个宏任务。
例如:去银行办理业务场景
分析代码的输出顺序
setTimeout(()=> { console.log(1); }) new Promise((resolve)=> { console.log(2); resolve() }).then(()=> { console.log(3); }) console.log(4);
正确的输出顺序:
分析:
- 先执行所有的同步任务
- 再执行微任务
- 再执行下一个宏任务