【C#】47. Task 的异常处理

就像在讨论线程的时候我们说过,要在线程调用的函数里面做try catch处理,如果在其他线程中使用try catch是无法正常捕获异常。Task也一样,基本原理就是一个线程没办法捕获另一个线程的异常

static int TaskMethod(string name, int seconds)
{
Console.WriteLine("Task {0} 运行在线程 {1} 上。是否是线程池线程: {2}",
name, Thread.CurrentThread.ManagedThreadId, Thread.CurrentThread.IsThreadPoolThread);
throw new Exception("Boom!");
return 42 * seconds;
}

TaskMethod内部并没用try catch 处理,只是抛出一个异常(Boom)。

首先,我们来看一下在主线程中加入Try catch能否正确处理异常:

Task<int> task;
try
{
task = Task.Run(() => TaskMethod("Task 1", 2));
int result = task.Result;
Console.WriteLine("Result: {0}", result);
}
catch
C#中的`Task.Run`方法主要用于在后台线程上启动一项任务,同时这个方法返回一个`Task`对象,它表示异步操作的未来完成。通常,`Task.Run`被用来执行一些计算密集型或IO密集型操作,以避免阻塞主线程。 当你调用`Task.Run`时,它会将给定的委托(通常是一个lambda表达式或方法引用)提交给线程池执行。线程池是一组可重用的工作线程,可以在需要时执行任务,而无需为每个任务创建新的线程,从而提高了性能和资源利用率。 下面是一个`Task.Run`的基本用法示例: ```csharp using System; using System.Threading.Tasks; class Program { static void Main(string[] args) { // 在后台线程上执行耗时的操作 Task.Run(() => { // 这里写耗时的操作代码 Console.WriteLine("执行耗时操作"); }).ContinueWith((antecedent) => { // 这里可以处理耗时操作的结果或后续操作 Console.WriteLine("耗时操作完成"); }); // 主线程代码 Console.WriteLine("主线程继续执行其它操作"); Console.ReadLine(); // 防止程序立即退出 } } ``` 在这个例子中,`Task.Run`启动了一个后台任务来执行耗时的操作,主线程继续执行其它操作,而不会被阻塞。当后台任务完成后,可以使用`ContinueWith`方法来指定一个任务,该任务将在后台任务完成后执行。 需要注意的是,在.NET Core和.NET 5/6/7等更新版本中,`Task.Run`可能会检查是否在UI线程中调用,如果是,则可能会抛出异常,因为UI线程不允许在后台线程上进行更新。在这种情况下,你可能需要使用`Task.Run`的其他重载版本或使用`Task.ConfigureAwait`方法来处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值