gpt4 book ai didi

c# - 没有样板的异步代码中的简单一般异常处理

转载 作者:太空宇宙 更新时间:2023-11-03 20:48:37 24 4
gpt4 key购买 nike

我们开始在应用程序中大量使用 CancellationToken,因此我们必须相应地更改异常处理:

class Program
{
static async Task Main(string[] args)
{
CancellationTokenSource cts = new CancellationTokenSource(100);
await DoJob(cts.Token);
Console.WriteLine("Successfully finished");
}

private static async Task DoJob(CancellationToken ct)
{
try
{
await Task.Delay(1000, ct);
}
catch (Exception e) when(!(e is OperationCanceledException))
{
Console.WriteLine("Do cleanup in case of error.");
}
}
}

这段代码背后的想法是,如果有人使用catch(Exception e)(请不要为此责怪我)而忘记排除CancellationToken,则执行错误处理,例如,有日志说操作失败。但事实并非如此,id 并没有失败,它只是被取消了。取消的处理方式应与失败的处理方式不同。

在我看来,几乎可以在每个一般捕获中编写一个大样板

catch (Exception e) when(!(e is OperationCanceledException))

是否有一些样板文件更少的更强大的解决方案?

最佳答案

您可以创建一个接受 Func<Task> 的方法并捕获异常,例如:

class Program
{
static async Task Main(string[] args)
{
CancellationTokenSource cts = new CancellationTokenSource(100);
await GeneralDoJobAndCatchException(() => DoJob(cts.Token));
Console.WriteLine("Successfully finished");
}

private static async Task GeneralDoJobAndCatchException(Func<Task> func)
{
try
{
await func();
}
catch (OperationCanceledException) { }
catch (Exception e)
{
Console.WriteLine("Do error handling");
}
}

private static async Task DoJob(CancellationToken ct)
{
await Task.Delay(1000, ct);
}
}

关于c# - 没有样板的异步代码中的简单一般异常处理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57974093/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com