推荐优先使用Task而非Thread实现多线程,因Task基于线程池,支持异步、取消、等待、异常传播和组合;Thread更底层、难管理,仅适用于需完全控制线程生命周期的极少数场景。
在C#中实现多线程,推荐优先用 Task,而不是直接操作 Thread。Thread 更底层、难管理;Task 基于线程池,支持异步、取消、等待、异常传播和组合,是现代 C# 并发编程的标准方式。
Thread 适合极少数需要完全控制线程生命周期的场景(如长时间运行的后台服务线程),但容易出错,不推荐日常使用。
var t = new Thread(() => { Console.WriteLine("运行在线程:" + Thread.CurrentThread.ManagedThreadId); }); t.Start(); t.Join(); // 等待完成
Task 封装了线程调度逻辑,自动利用线程池,支持 await、ContinueWith、WaitAll/Any、取消令牌等关键能力。
Task,比如 Task t = Task.Run(() => 42);
这是最常用、最安全的模式,适用于 CPU 密集型工作(如计算、编码、解析)。
async TaskComputeAsync() { return await Task.Run(() => { Thread.Sleep(1000); // 模拟耗时计算 return 123; }); } // 调用 int result = await ComputeAsync(); Console.WriteLine(result);
真实项目中必须考虑任务可取消和错误恢复。
var cts = new CancellationTokenSource(); cts.CancelAfter(2000);try { var task = Task.Run(() => { for (int i = 0; i < 10; i++) { cts.Token.ThrowIfCancellationRequested(); Thread.Sleep(500); } return "done"; }, cts.Token);
string result = await task;} catch (OperationCanceledException) { Console.WriteLine("任务被取消"); }
基本上就这些。Thread 是“能用但不该用”,Task.Run + async/await 是“该用也够用”。别再手写 Thread.Start/Join/Abort,Task 已经帮你封装好所有复杂性。