首页
学习
活动
专区
圈层
工具
发布

如何优雅的不用try-catch捕获await的错误

在日常开发中,通常我们会用 promise 的形式来进行一些异步的操作,但是为了更方便,我们也会较多的使用语法糖 async await 的形式,但是这两者有个区别,promise 可以使用 .catch...来捕获问题,但是 async await 却只能使用 try catch 来捕获,这样写起来很不友好,代码中充斥着大量的 try catch,类似这种 (async () => { try {...->', err) } })() 如果要对每个接口进行 try catch 捕获,代码层面无疑是臃肿的,那有没有什么较好的方式呢?...,一个是成功后返回的数据 (async () => { const [err, data] = await getList().then(data => [null, data]).catch(err...其实有一个 await-to-js 的库,是专门做这个操作的,我看了一下源码,非常简单,就拿过来直接看吧,思想都是一样的,源码很短,只有 23 行,其中还包括注释和空行,主要的思想跟之前我们的思路都是一样的

88110
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Async,Await和ConfigureAwait的关系

    虽然async / await让异步编程更简单,但是有一些你可能不知道的细节和注意的地方 新关键字 微软在.NET框架中添加了async和await关键字。...使用async/ await,其他人可以在你点完菜之后下他们的订单,并且可以同时处理多个订单。 它不能做什么? 这里需要注意的一件事是async/await并不是并行/多核编程。...这里的问题是,每个async/ await对于调用它的当前方法都是本地的。因此,调用链的每个异async/await都可能最终在不同的线程上恢复。...首先,调用方法不能try/catch调用中的任何异常。它最终将进入AppDomain UnhandledException事件。...不过,如果在实际的async void方法中放入一个try catch,就可以有效地防止这种情况发生。另一个问题是调用者永远不会知道它何时结束,因为它不返回任何东西。

    95510

    Async和Await异步编程的原理

    Async和Await异步编程的原理 1. 简介 从4.0版本开始.NET引入并行编程库,用户能够通过这个库快捷的开发并行计算和并行任务处理的程序。...在4.5版本中.NET又引入了Async和Await两个新的关键字,在语言层面对并行编程给予进一步的支持,使得用户能以一种简洁直观的方式实现并行编程。...因为在很多文档里针对Async和Await这两个关键字的使用都被称为异步编程,为了更符合大众的阅读习惯,我们使用异步编程这个叫法,意思上和并行编程完全一样。...Async和Await的实现 前面提到了yield关键字,用于简化遍历的实现。如果您熟悉yield这个关键字的应用,就会发现await关键字的出现位置、使用方式以及运行逻辑和yield是如此的相似。...事实的确如此,await和async也是一种基于编译器的功能(C#和VB.NET都提供了这个功能),不仅如此,它在实现原理上也和yield非常像——await/async和yield都被编译器在编译时转化为了状态机

    1.4K10

    使用 Async 和 Await 的异步编程

    这与人们为包含异步任务的流程给予指令的方式类似。在本文中,你将通过做早餐的指令示例来查看如何使用 async 和 await 关键字更轻松地推断包含一系列异步指令的代码。...; 接下来,可以在提供早餐之前将用于处理培根和鸡蛋的 await 语句移动到此方法的末尾: C#复制 Coffee cup = PourCoffee(); Console.WriteLine("Coffee...上述方式的签名中具有 async 修饰符。...它会向编译器发出信号,说明此方法包含 await 语句;也包含异步操作。此方法表示先烤面包,然后再添加黄油和果酱的任务。此方法返回表示这三个操作的组合的 Task。...async 和 await 的语言功能支持每个人做出转变以遵循这些书面指示:尽可能启动任务,不要在等待任务完成时造成阻塞。

    1.6K30

    node.js的async和await

    一、async和await是什么 ES2017 标准引入了 async 函数,使得异步操作变得更加方便,async其实本质是Generator函数的语法糖 async表示函数里有异步操作 await表示在后面的表达式需要等待结果...async函数返回的是一个Promise对象,可以使用then方法添加回调函数,一旦遇到await就会先返回。...和await async 函数本质就是 Generator 函数的语法糖 最后演变成了下面这样的写法 const asyncReadFile = async function () { const...()); console.log(f2.toString()); }; async和await,比起*和yield,语义更清楚了。...async表示函数里有异步操作,await表示在后面的表达式需要等待结果 async函数的返回值是Promise对象 await后面,可以是Promise对象和原始类型的值(数值、字符串和布尔值,会自动转换成

    2.1K30

    async和await的使用总结 ~ 竟然一直用错了c#中的async和await的使用。。

    对于c#中的async和await的使用,没想到我一直竟然都有一个错误。。 。。还是总结太少,这里记录下。 这里以做早餐为例 流程如下: 倒一杯咖啡。 加热平底锅,然后煎两个鸡蛋。 煎三片培根。...可以看出,这样编写的异步和最初同步版本的总共的耗时大致相同。 这是因为这段代码还没有利用异步编程的某些关键功能。 即上面的异步代码的使用在这里是不准确的。...; 接下来,可以在提供早餐之前将用于处理培根和鸡蛋的await语句移动到此方法的末尾: Coffee cup = PourCoffee(); Console.WriteLine("coffee is ready...与任务组合 吐司操作由异步操作(烤面包)和同步操作(添加黄油和果酱)组成。 这里涉及到一个重要概念: 异步操作后跟同步操作的这种组合也是一个异步操作。...总结: async 和 await的功能最好能做到: 尽可能启动任务,不要在等待任务完成时造成阻塞。 即可以先把任务存储到task,然后在后面需要用的时候,调用await task()方法。

    2.1K10

    Vue中异步:Async和await的使用

    bug收集:专门解决与收集bug的网站 最近,在写在项目中很多的地方,用到了async和await。...发现了和理解的有些不一样, 下面有几道网上看到的题,大家可以做做,看看和你想的是否一样 async function test() { console.log(0) await console.log...会阻塞该方法内部后续的进程(等待时间比同步方法久,先执行同步方法) 再看以下示例帮助理解: let x = 0; async function test() { x += await 2;...正确答案是:2 首先我们先记住一句话,那就是异步函数(async方式声明的函数)不代表其函数内部的所有代码都是异步方式执行的,这句话什么意思呢?...0替换,然后才轮到test函数外的x = 1这行代码执行,x += await 2相当于x = 0 + await 2,所以最终输出:2 现在,我们稍微对上面的代码做一下修改: let x = 0; async

    92110

    如何简单理解 JavaScript 的 Async 和 Await?

    ,实站await 等待、连续输入文字、在循环里调用,让这些过去需要层层callback才能完成的流程,透过 Async 和 Await 轻松的进行扁平化处理吧!...在JavaScript的世界,同步sync和非同步async的爱恨情仇,就如同偶像剧一般的剪不断理还乱,特别像是setTimeout、setInterval、MLHttpRequest或fetch这些同步非同步混杂的用法...02 利用async 和 await 做个「漂亮的等待」 了解 async 和 await 的意思之后,就来试试看做个「漂亮的等待」: ?...04 搭配Fetch 在上篇的文章 JavaScript Fetch API 使用教学已经有提到 fetch 的用法,因为 fetch 最后回传的是promise,理所当然的通过 async 和await...坦白说只要你一但熟悉了async 和await,就真的回不去了,虽然说callback 仍然我们开发中会用到,但对于同步和非同步之间的转换,以后就交给 async 和await来处理吧!

    1.6K20

    javascript中优雅的处理async和await异常

    function() { let result = await handler(false).catch(); console.log(result); result = await...: Error: 执行失败,给出错误 async函数总是返回promise实例 无论是return了Promise, 还是内部调用了await, 就算什么也没做,它也返回promise; 一个函数...,只要被标记了async,那么它就返回Promise对象 所以上面的handler函数返回的是一个promise实例 如果一个 async 函数返回的是一个 reject 的 Promise,那么这个...这行代码:let result = await handler(false).catch(); 返回的是resolve状态的promise result = await handler(true)....catch(); 返回的是reject状态的promise await一个resolve状态的promise,无论有没有catch,都直接得到结果 await一个reject状态的promise

    1.1K20

    C# 中的Async 和 Await 的用法详解

    众所周知C#提供Async和Await关键字来实现异步编程。在本文中,我们将共同探讨并介绍什么是Async 和 Await,以及如何在C#中使用Async 和 Await。...要解决这个问题,我们必须在传统编程中编写很多的代码,但是现在我们有了Async 和 await关键字,那么我们将通过书写很少的并且简洁的代码来解决这个问题。...Async 和 await是代码标记,它标记代码位置为任务完成后控件应该恢复的位置。...在Async 和 await关键字的帮助下,我们可以在实时项目中使用所有这些,以便更快地执行任务。...像上面这种简单的方式一样,我们可以在C#代码中使用async 和await关键字来愉快的进行异步编程了。 最后的最后感谢大家的阅读!

    2.4K60
    领券