C# 线程同步之事件信号阻塞 AutoResetEvent
时间:2022-07-24
本文章向大家介绍C# 线程同步之事件信号阻塞 AutoResetEvent,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
AutoResetEvent可以在线程与线程间传递信号,来告知其他线程自己已经完成某一阶段的任务。
两个AutoResetEvent实例的初始状态都是unsignaled。 调用任何一个WaitOne都会阻塞,直到Set。
如果初始状态(new时给了true)为Signaled,则WaitOne会立刻执行,然后自动切换回unsignaled
AutoResetEvent采用内核时间模式,等待时间不能太长。 这能被更好的ManualResetEventslim类替换,因为它是混合模式。
下方输出结果:
1等待另一个线程完成工作 2开始一个长期工作 3工作完成 4等待中线程完成它的工作 5第一阶段工作完成 6在主线程上做了些操作 7现在开始由第二线程执行第二阶段 8开始第二阶段 9工作完成 10工作全部完成
private static AutoResetEvent _workerEvent = new AutoResetEvent(false);
private static AutoResetEvent _mainEvent = new AutoResetEvent(false);
static void Process(int seconds)
{
Console.WriteLine("2开始一个长期工作");
Thread.Sleep(seconds);
Console.WriteLine("3工作完成");
Console.WriteLine("4等待中线程完成它的工作");
_workerEvent.Set();
_mainEvent.WaitOne();
Console.WriteLine("8开始第二阶段");
Thread.Sleep(seconds);
Console.WriteLine("9工作完成");
_workerEvent.Set();
}
static void Main(string[] args)
{
var t = new Thread(() => Process(10));
t.Start();
Console.WriteLine("1等待另一个线程完成工作");
_workerEvent.WaitOne();
Console.WriteLine("5第一阶段工作完成");
Console.WriteLine("6在主线程上做了些操作");
Thread.Sleep(5);
Console.WriteLine("7现在开始由第二线程执行第二阶段");
_mainEvent.Set();
_workerEvent.WaitOne();
Console.WriteLine("10工作全部完成");
Console.ReadLine();
}
- Flask一步步搭建web应用
- (44) 剖析TreeSet / 计算机程序的思维逻辑
- (46) 剖析PriorityQueue / 计算机程序的思维逻辑
- (48) 剖析ArrayDeque / 计算机程序的思维逻辑
- 那些年在win下填过的Django坑
- Python爬虫一步步抓取房产信息
- (47) 堆和PriorityQueue的应用 / 计算机程序的思维逻辑
- 一篇文章完全理解virtualenv
- Python运用蒙特卡洛算法模拟植物生长
- (57) 二进制文件和字节流 / 计算机程序的思维逻辑
- 真正的 Tornado 异步非阻塞
- (58) 文本文件和字符流 / 计算机程序的思维逻辑
- Python爬虫—破解JS加密的Cookie
- Python通过抓包和使用cookie爬取微博完全讲解
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 《hdu 4540 威威猫打地鼠》
- 多个请求下 loading 的展示与关闭
- 第13期:表统计信息的计算
- 2019.8.15乘兴打Codeforces Round #569 (Div. 2)小记A题A. Alex and a Rhombus
- 2019.8.15乘兴打Codeforces Round #569 (Div. 2)小记B. Nick and Array
- 《hdu 免费馅饼》
- 技术分享 | 使用 pt-query-digest 分析慢日志
- 2019.8.15乘兴打Codeforces Round #569 (Div. 2)小记
- Codeforces Beta Round #14 (Div. 2)A. Letter
- Vue 改变数据,页面不刷新的问题
- R语言再保险合同定价案例研究
- 开发一个简单的 Vue 弹窗组件
- R语言模拟人类生活预期寿命动态可视化动画图gif
- Vue 动态添加路由及生成菜单
- R语言泊松回归对保险定价建模中的应用:风险敞口作为可能的解释变量