C# 4.0 等待线程结束

在C#中,如果你正在使用多线程编程,并且想要等待一个或多个线程完成它们的工作再继续执行,有几种方式可以实现。从C# 4.0开始,虽然直接用于等待线程结束的特性(如Thread.Join())在之前的版本中也已经存在,但C# 4.0引入了Task类,它提供了更现代、更灵活的方式来处理异步操作和并行编程。

使用Thread.Join()

虽然这不是C# 4.0引入的,但Thread.Join()方法是最直接的方式来等待一个线程完成。你只需调用你想要等待的线程的Join()方法即可。这个方法会阻塞当前线程,直到被调用的线程执行完毕。

复制代码
Thread thread = new Thread(new ThreadStart(DoWork));  
thread.Start();  
  
// 等待线程结束  
thread.Join();  
  
Console.WriteLine("线程已结束");

使用 Task

从C# 4.0开始,Task类被引入以支持更高级的异步编程模式。Task提供了一种更简洁的方式来表示异步操作,并且可以与await关键字(在C# 5.0及更高版本中引入)一起使用,以实现非阻塞的等待。

创建并等待Task
复制代码
Task task = Task.Run(() => DoWork());  
  
// 等待Task完成  
task.Wait();  
  
Console.WriteLine("Task已结束");

注意:Task.Wait()Thread.Join()都会阻塞调用它们的线程,直到等待的操作完成。

使用await(C# 5.0及更高版本)

如果你使用的是C# 5.0或更高版本,并且你的方法是一个async方法,你可以使用await关键字来非阻塞地等待Task完成。

复制代码
async Task Main(string[] args)  
{  
    Task task = Task.Run(() => DoWork());  
  
    // 等待Task完成,但不会阻塞当前线程  
    await task;  
  
    Console.WriteLine("Task已结束");  
}  
  
void DoWork()  
{  
    // 模拟一些工作  
    Thread.Sleep(1000);  
}

在这个例子中,Main方法被标记为async,这允许我们在其中使用await。调用await task;时,Main方法的执行会在当前位置暂停,直到task完成,但此时不会阻塞调用Main方法的线程(在控制台应用程序中,这通常是主线程)。await使得异步代码看起来和写起来都像同步代码一样简单。

总结

对于C# 4.0,如果你需要等待线程结束,Thread.Join()是一个直接的选择。然而,如果你有机会使用更高版本的C#,那么使用Taskawait将提供更灵活、更强大的异步编程能力。

相关推荐
yangchanghua1111 小时前
pgsql 如何查询今天范围内的数据(当天0点0分0秒 - 当天23点59分59秒....)
数据库·pgsql
larance1 小时前
SQLAlchemy 的异步操作来批量保存对象列表
数据库·python
python_chai1 小时前
从数据汇总到高级分析,SQL 查询进阶实战(下篇)—— 分组、子查询与窗口函数全攻略
数据库·sql·mysql
在努力的前端小白2 小时前
Spring Boot 敏感词过滤组件实现:基于DFA算法的高效敏感词检测与替换
java·数据库·spring boot·文本处理·敏感词过滤·dfa算法·组件开发
未来之窗软件服务2 小时前
自建知识库,向量数据库 (九)之 量化前奏分词服务——仙盟创梦IDE
数据库·仙盟创梦ide·东方仙盟·自建ai·ai分词
好望角雾眠4 小时前
第一阶段C#基础-10:集合(Arraylist,list,Dictionary等)
笔记·学习·c#
冒泡的肥皂5 小时前
MVCC初学demo(一
数据库·后端·mysql
.Shu.6 小时前
Redis Reactor 模型详解【基本架构、事件循环机制、结合源码详细追踪读写请求从客户端连接到命令执行的完整流程】
数据库·redis·架构
薛晓刚9 小时前
当MySQL的int不够用了
数据库
SelectDB技术团队9 小时前
Apache Doris 在菜鸟的大规模湖仓业务场景落地实践
数据库·数据仓库·数据分析·apache doris·菜鸟技术