setTimeout、Promise、Async/Await 的区别
个人题解
- setTimeout 只是一个异步的定时器,用来执行多少时间后的任务
- promise 是一个规范,用then,catch,all,race等方法更好的处理异步内容
- async/await 是一个promise的语法糖,不了解具体的实现
没想到是考察宏任务,微任务的,打扰了.草.
最高赞题解
setTimeout
1 | console.log('script start') //1. 打印 script start |
- Promise
Promise本身是同步的立即执行函数, 当在executor中执行resolve或者reject的时候, 此时是异步操作, 会先执行then/catch等,当主栈完成后,才会去调用resolve/reject中存放的方法执行,打印p的时候,是打印的返回结果,一个Promise实例。
1
2
3
4
5
6
7
8
9
10
11
12
13console.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当JS主线程执行到Promise对象时,
promise1.then() 的回调就是一个 task
promise1 是 resolved或rejected: 那这个 task 就会放入当前事件循环回合的 microtask queue
promise1 是 pending: 这个 task 就会放入 事件循环的未来的某个(可能下一个)回合的 microtask queue 中
setTimeout 的回调也是个 task ,它会被放入 macrotask queue 即使是 0ms 的情况
async/await
1 | async function async1(){ |
async 函数返回一个 Promise 对象,当函数执行的时候,一旦遇到 await 就会先返回,等到触发的异步操作完成,再执行函数体内后面的语句。可以理解为,是让出了线程,跳出了 async 函数体。
- 举个例子:
1 | async function func1() { |
- 在这里插入图片描述
- 很显然,func1的运行结果其实就是一个Promise对象。因此我们也可以使用then来处理后续逻辑。
1 | func1().then(res => { |
await的含义为等待,也就是 async 函数需要等待await后的函数执行完成并且有了返回结果(Promise对象)之后,才能继续执行下面的代码。await通过返回一个Promise对象来实现同步的效果。
更多可见setTimeout、Promise、Async/Await
浏览器的Tasks、microtasks、 queues 和 schedules #21
第 8 题:setTimeout、Promise、Async/Await 的区别 #33