推荐优先使用Task而非Thread实现多线程,因Task基于线程池,支持异步、取消、等待、异常传播和组合;Thread更底层、难管理,仅适用于需完全控制线程生命周期的极少数场景。

在C#中实现多线程,推荐优先用 Task,而不是直接操作 Thread。Thread 更底层、难管理;Task 基于线程池,支持异步、取消、等待、异常传播和组合,是现代 C# 并发编程的标准方式。
Thread:简单但需手动管理
Thread 适合极少数需要完全控制线程生命周期的场景(如长时间运行的后台服务线程),但容易出错,不推荐日常使用。
- 创建后必须显式调用 Start() 才会执行
- 不能重复 Start;不能 Join 已结束的线程;无法返回值
- 异常不会自动向主线程传播,需在线程内 try-catch 处理
- 示例:
var t = new Thread(() => {
Console.WriteLine("运行在线程:" + Thread.CurrentThread.ManagedThreadId);
});
t.Start();
t.Join(); // 等待完成
登录后复制
Task:默认首选,简洁可靠
Task 封装了线程调度逻辑,自动利用线程池,支持 await、ContinueWith、WaitAll/Any、取消令牌等关键能力。
- 启动即运行:Task.Run() 或 Task.Factory.StartNew() 会立即排队执行
-
可返回结果:用
Task<t></t>,比如Task<int> t = Task.Run(() => 42);</int> - 支持 async/await:真正实现非阻塞等待,避免线程浪费
- 统一异常处理:await 或 Wait() 时集中抛出所有异常(AggregateException)
推荐写法:用 Task.Run + async/await
这是最常用、最安全的模式,适用于 CPU 密集型工作(如计算、编码、解析)。
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~