我为什么不在async函数中使用try…catch?

广告位招租
扫码页面底部二维码联系

总之一句话:在async函数中使用try【作者:唐霜】【版权所有,侵权必究】…catch会导致调试难道增未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。加。且任何使用使用try…c【版权所有】唐霜 www.tangshuang.net【关注微信公众号:wwwtangshuangnet】atch的场景,都会增加调试难度,比如r原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。eact的报错信息,有的时候,你怎么都找【版权所有,侵权必究】【原创内容,转载请注明出处】不到问题代码具体在哪个位置。

著作权归作者所有,禁止商业用途转载。著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshuang.net【原创不易,请尊重版权】

当一个Error产生的时候,Error会原创内容,盗版必究。【转载请注明来源】用stack字段记录该Error产生的具【版权所有】唐霜 www.tangshuang.net原创内容,盗版必究。体位置。只有,我们得到原始的Error,原创内容,盗版必究。【未经授权禁止转载】才能获得原始的stack信息,但是通过t【未经授权禁止转载】【版权所有,侵权必究】ry…catch语法,往往会【未经授权禁止转载】本文版权归作者所有,未经授权不得转载。屏蔽原始的Error,导致我们追逐不到错未经授权,禁止复制转载。【原创不易,请尊重版权】误的原始位置。比如:

【本文受版权保护】【版权所有,侵权必究】【原创不易,请尊重版权】
<script>
  'use strict'

  async function calc() {
    try {
      const x = await a + await b
      const y = x + await z
      return y
    }
    catch (e) {
      alert('计算错误')
    }
  }

  calc()
</script>

我们用alert来替代我们经常使用的to本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshuang.netast, popup等方法。一旦我们通过未经授权,禁止复制转载。著作权归作者所有,禁止商业用途转载。交互形式接住错误时,我们就直接放弃了获得未经授权,禁止复制转载。原创内容,盗版必究。错误原始信息的权利。

【关注微信公众号:wwwtangshuangnet】著作权归作者所有,禁止商业用途转载。著作权归作者所有,禁止商业用途转载。

async函数本质上是创建一个异步函数,【转载请注明来源】【原创内容,转载请注明出处】而非创建一个封闭式的闭包。没错,如果你在【访问 www.tangshuang.net 获取更多精彩内容】【关注微信公众号:wwwtangshuangnet】async函数中使用try…【版权所有,侵权必究】【本文首发于唐霜的博客】catch跟使用闭包没有什么区别。异步函【本文受版权保护】【关注微信公众号:wwwtangshuangnet】数的目标,是完成异步操作,但其中重要的一【版权所有】唐霜 www.tangshuang.net【关注微信公众号:wwwtangshuangnet】点是,它的错误是可以被捕获的。为了实现这【未经授权禁止转载】【本文受版权保护】种捕获,有些开发者会在 catch 中再【作者:唐霜】原创内容,盗版必究。次把错误抛出来,比如 catch (e)【版权所有,侵权必究】【版权所有】唐霜 www.tangshuang.net { throw e }。但是这样做,会【版权所有】唐霜 www.tangshuang.net本文版权归作者所有,未经授权不得转载。导致程序在这里又结束了。所以,这种做法又【本文受版权保护】本文作者:唐霜,转载请注明出处。不符合在async函数中使用try【转载请注明来源】【本文受版权保护】230;catch的目的。

【版权所有】唐霜 www.tangshuang.net【版权所有,侵权必究】【未经授权禁止转载】【版权所有】唐霜 www.tangshuang.net

对于我个人而言,我从来不直接在async【访问 www.tangshuang.net 获取更多精彩内容】著作权归作者所有,禁止商业用途转载。函数中使用try…catch【本文受版权保护】本文作者:唐霜,转载请注明出处。,定义async函数是一个纯粹的asyn著作权归作者所有,禁止商业用途转载。【作者:唐霜】c…await结构,在使用该【版权所有,侵权必究】【作者:唐霜】函数时,使用.then().catch(【版权所有】唐霜 www.tangshuang.net【本文受版权保护】).finally()接住函数执行过程中【访问 www.tangshuang.net 获取更多精彩内容】【本文首发于唐霜的博客】的结果逻辑。

【原创内容,转载请注明出处】转载请注明出处:www.tangshuang.net原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。【本文受版权保护】
已有2条评论
  1. rxxy 2021-01-14 17:28

    要正确使用

  2. rxliuli 2021-01-13 12:07

    有点误人子弟了。。。async 函数中的 try/catch 和 then/catch 没什么区别吧?