async/await不阻塞事件

本文探讨了async/await在JavaScript中的工作原理,指出它们在函数内部创建了同步式的外观,但实际上不会阻塞事件循环。通过示例代码展示了即使在await之后,代码仍会以异步方式执行,不会影响其他并发任务。这表明async函数仅在其内部暂停,允许其他任务继续运行。对于开发者来说,理解这一点有助于优化并发处理和避免误解。
摘要由CSDN通过智能技术生成

在我的认知中,async/await会等待await返回,那么必然就是同步的,既然是同步的,那么就是会阻塞事件循环。

刚好有个同事问了一个接口并发的问题,看了一下代码,我看见有使用async/await,于是信誓旦旦的说会阻塞,结果打脸了,结果是并不会,看下面代码:

async function fn1(){
  console.log(1);
  await pr1();
  await pr2();
  console.log(2);
};

function fn2(){
  console.log(3);
};

function pr1(){
  return new Promise((resolve, reject) => {
    setTimeout(() => {
      console.log(4);
      resolve();
    }, 2000);
  });
};

function pr2(){
  return new Promise((resolve, reject) => {
    setTimeout(() => {
      console.log(5);
      resolve();
    }, 2000);
  });
};

fn1();
fn2();

如果会阻塞,输出应该是14523,结果是13452,这就表示async/await是不会阻塞,会阻塞的只是使用await的函数内部。

因为是在vue项目,我也在vue的生命周期试了一下:

async created(){
  console.log(1);
  await this.pr1();
  await this.pr2();
  console.log(2);
},
async mounted() {
  console.log(3);
},
methods:{
  pr1(){
    return new Promise((resolve, reject) => {
      setTimeout(() => {
        console.log(4);
        resolve();
      }, 2000);
    });
  },
  pr2(){
    return new Promise((resolve, reject) => {
      setTimeout(() => {
        console.log(5);
        resolve();
      }, 2000);
    });
  }
}

结果也是13452,所以,async/await只会阻塞函数内部。

但其实还是有一点没搞懂,async函数里面碰见了await,之后的事件是当作什么处理,看执行结果,先进入函数执行,然后把await之后的当作异步的,直接跳出这个函数。暂时就不深入研究了。

coding个人笔记 订阅号

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值