await有一个最让我不能理解的点就是怎么能做到阻塞异步的同时也将其下的同步语句阻塞。
都知道yield+promise能做到异步阻塞,但我写不出将后面的同步语句也阻塞的方法。
我的写法实现如下:
function mission(){
return new Promise(resolve=>{
setTimeout(()=>{
resolve(123);
},1000);
});
}
function *test(){
const res=yield mission();
console.log(res);
}
function handler(gen,data){
const {value,done}=gen.next(data);
if(!done){
if(value instanceof Promise){
value.then(res=>handler(gen,res));
}else{
handler(gen);
}
}else{
gen.next(value);
}
}
function fn(){
handler(test());
//这里无法被阻塞!
console.log(321);
//打印结果为:
// 321
// 123
}
fn();
但是当我改写成async的写法时却能做到阻塞。
//改写fn函数
async function fn(){
await mission();
console.log(321);
}
fn();
//打印结果为:
// 123
// 321
所以我想请问一下各位大佬,如果用yield+promise写出async的效果?