[C#]『CountdownEvent』任务并行库使用小计
System.Threading.CountdownEvent 是一个同步基元,它在收到一定次数的信号之后,将会解除对其等待线程的锁定。 CountdownEvent 专门用于以下情况:您必须使用 ManualResetEvent 或 ManualResetEventSlim,并且必须在用信号通知事件之前手动递减一个变量。 例如,在分叉/联接方案中,您可以只创建一个信号计数为 5 的 CountdownEvent,然后在线程池上启动五个工作项,并且让每个工作项在完成时调用 Signal。 每次调用 Signal 时,信号计数都会递减 1。 在主线程上,对 Wait 的调用将会阻塞,直至信号计数为零。
CountdownEvent 具有这些附加功能:
•可通过使用取消标记来取消等待操作。
•创建实例之后可以递增它的信号计数。
•通过调用 Reset 方法,可在 Wait 返回之后重用实例。
•实例公开 WaitHandle 以便与其他 .NET Framework 同步 API(例如 WaitAll)进行集成。——MSDN
1.普通示例
using System; using System.Threading; using System.Threading.Tasks; namespace ConsoleApplication18 { class Program { static CountdownEvent cde = null; /// <summary> /// 模拟建房子 /// </summary> /// <param name="args"></param> static void Main(string[] args) { //建房子第一期工人 string[] _bhPerson1 = new string[5] { "Yan", "Zhi", "wei", "Do", "Work" }; //建房子第二期工人 string[] _bhPerson2 = new string[3] { "Yan2", "Zhi2", "wei2" }; //建房子第三期工人 string[] _bhPerson3 = new string[3] { "Yan3", "Zhi3", "wei3" }; using (cde = new CountdownEvent(Environment.ProcessorCount))//开始监管,相当于监工 { cde.Reset(_bhPerson1.Length);//设置第一期建造需要5个人 foreach (string person in _bhPerson1) { Task.Factory.StartNew(() => { BuilderHourseStep1(person); }); } cde.Wait();//等待第一期建造完成 Console.WriteLine("-----------------------"); cde.Reset(_bhPerson2.Length);//设置第二期建需要三个人 foreach (string person in _bhPerson2) { Task.Factory.StartNew(() => { BuilderHourseStep2(person); }); } cde.Wait();//等待第二期建造完成 Console.WriteLine("-----------------------"); cde.Reset(_bhPerson3.Length);//设置第三期建需要三个人 foreach (string person in _bhPerson3) { Task.Factory.StartNew(() => { BuilderHourseStep3(person); }); } cde.Wait();//等待第三期建造完成 Console.WriteLine("-----------------------"); } } /// <summary> /// 建房子第一道所需要的工序 /// </summary> /// <param name="person"></param> static void BuilderHourseStep1(string person) { try { Console.WriteLine(string.Format("『{0}』BuilderHourseStep1....", person)); } finally { cde.Signal();//建造完成一点后,通知监工 } } /// <summary> /// 建房子第二道所需要的工序 /// </summary> /// <param name="person"></param> static void BuilderHourseStep2(string person) { try { Console.WriteLine(string.Format("『{0}』BuilderHourseStep2.....", person)); } finally { cde.Signal(); } } /// <summary> /// 建房子第三道所需要的工序 /// </summary> /// <param name="person"></param> static void BuilderHourseStep3(string person) { try { Console.WriteLine(string.Format("『{0}』BuilderHourseStep3.......", person)); } finally { cde.Signal(); } } } }
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }
代码效果
2.超时演示,延续上面例子,建造房子存在延期的情况,譬如某个工作工作懒散,那么需要给整个一期建造设置一个总的时限。
using System; using System.Threading; using System.Threading.Tasks; namespace ConsoleApplication18 { class Program { static CountdownEvent cde = null; static int overLimitTime = 5000;//第一期工作完成时间 /// <summary> /// 模拟建房子 /// </summary> /// <param name="args"></param> static void Main(string[] args) { try { //建房子第一期工人 string[] _bhPerson1 = new string[5] { "Yan", "Zhi", "wei", "Do", "Work" }; //建房子第二期工人 string[] _bhPerson2 = new string[3] { "Yan2", "Zhi2", "wei2" }; //建房子第三期工人 string[] _bhPerson3 = new string[3] { "Yan3", "Zhi3", "wei3" }; using (cde = new CountdownEvent(Environment.ProcessorCount))//开始监管,相当于监工 { cde.Reset(_bhPerson1.Length);//设置第一期建造需要5个人 Random _workTime = new Random(); foreach (string person in _bhPerson1) { Task.Factory.StartNew(() => { int _doWorkTime = _workTime.Next(3000, 6000);//工人工作时间 BuilderHourseStep1(person, _doWorkTime); }); } bool _bdStep1Result = cde.Wait(overLimitTime); Console.WriteLine(string.Format("第一期建造状态:{0}.", _bdStep1Result == true ? "完成" : "延时"));//等待第一期建造完成 限制5秒内完成 Console.WriteLine("-----------------------"); if (!_bdStep1Result) return; cde.Reset(_bhPerson2.Length);//设置第二期建需要三个人 foreach (string person in _bhPerson2) { Task.Factory.StartNew(() => { BuilderHourseStep2(person); }); } cde.Wait();//等待第二期建造完成 Console.WriteLine("-----------------------"); cde.Reset(_bhPerson3.Length);//设置第三期建需要三个人 foreach (string person in _bhPerson3) { Task.Factory.StartNew(() => { BuilderHourseStep3(person); }); } cde.Wait();//等待第三期建造完成 Console.WriteLine("-----------------------"); } } catch (Exception ex) { Console.WriteLine(string.Format("Excepton Message: {0}", ex.Message.Trim())); } finally { Console.ReadLine(); } } /// <summary> /// 建房子第一道所需要的工序 /// </summary> /// <param name="person"></param> static void BuilderHourseStep1(string person, int doWorkTime) { bool _isDoWork = doWorkTime < overLimitTime; try { if (_isDoWork) Console.WriteLine(string.Format("『{0}』做事情花费了,{1}s........", person, doWorkTime)); else Console.WriteLine(string.Format("『{0}』做事情太墨迹,花费了{1}s....", person, doWorkTime)); Thread.Sleep(doWorkTime); } finally { if (_isDoWork) cde.Signal();//建造完成后,通知监工 } } /// <summary> /// 建房子第二道所需要的工序 /// </summary> /// <param name="person"></param> static void BuilderHourseStep2(string person) { try { Console.WriteLine(string.Format("『{0}』BuilderHourseStep2.....", person)); } finally { cde.Signal(); } } /// <summary> /// 建房子第三道所需要的工序 /// </summary> /// <param name="person"></param> static void BuilderHourseStep3(string person) { try { Console.WriteLine(string.Format("『{0}』BuilderHourseStep3.......", person)); } finally { cde.Signal(); } } } }
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }
代码效果
[C#]『CountdownEvent』任务并行库使用小计的更多相关文章
- [C#]『PLINQ』任务并行库使用小计
并行 LINQ (PLINQ) 是 LINQ to Objects 的并行实现. PLINQ 实现完整的 LINQ 标准查询运算符集作为 T:System.Linq 命名空间的扩展方法,并具有用于并行 ...
- [C#]『Barrier』任务并行库使用小计
Barrier 是一个对象,它可以在并行操作中的所有任务都达到相应的关卡之前,阻止各个任务继续执行. 如果并行操作是分阶段执行的,并且每一阶段要求各任务之间进行同步,则可以使用该对象. --MSDN ...
- [C#]『Task』任务并行库使用小计
1.简单创建使用 using System; using System.Diagnostics; using System.Threading; using System.Threading.Task ...
- C# 任务并行库使用小计 z
1.简单创建使用 using System; using System.Diagnostics; using System.Threading; using System.Threading.Task ...
- 『计算机视觉』imgaug图像增强库中部分API简介
https://github.com/aleju/imgaug 介绍一下官方demo中用到的几个变换,工程README.md已经给出了API简介,个人觉得不好理解,特此单独记录一下: import n ...
- 『TensorFlow』分布式训练_其二_单机多GPU并行&GPU模式设定
建议比对『MXNet』第七弹_多GPU并行程序设计 一.tensorflow GPU设置 GPU指定占用 gpu_options = tf.GPUOptions(per_process_gpu_mem ...
- 『开源』Slithice 2013 服务器集群 设计和源码
相关介绍文章: <『设计』Slithice 分布式架构设计-支持一体式开发,分布式发布> <『集群』001 Slithice 服务器集群 概述> <『集群』002 Sli ...
- 『计算机视觉』Mask-RCNN_推断网络其四:FPN和ROIAlign的耦合
一.模块概述 上节的最后,我们进行了如下操作获取了有限的proposal, # [IMAGES_PER_GPU, num_rois, (y1, x1, y2, x2)] # IMAGES_PER_GP ...
- 『计算机视觉』Mask-RCNN
一.Mask-RCNN流程 Mask R-CNN是一个实例分割(Instance segmentation)算法,通过增加不同的分支,可以完成目标分类.目标检测.语义分割.实例分割.人体姿势识别等多种 ...
随机推荐
- JS 事件与事件对象小结
JavaScript与HTML之间的交互是通过事件来实现的.IE9,chrome,Firefox,Opera,Safari均实现了DOM2级规范中定义的标准DOM事件,而IE8和IE8以下版本仍然保留 ...
- Git简介:
Git中文文档 1.详解在Visual Studio中使用git版本系统(图文) 2.GitExtensions下载地址:http://gitextensions.codeplex.com/ 3.Gi ...
- 微信开发第7章 通过accesstoken获取用户黑名单列表
获取黑名单列表可以查看文档 http://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1471422259_pJMWA&token=& ...
- C#- 操作Ini文件
以前习惯了使用.NET中的WEB.CONFIG或者APP.CONFIG,最近在做项目的时候遇到了些问题,发现没办法使用这些CONFIG文件.一开始我的做法是建一个文本文件,自己定规律,自己写方法去写新 ...
- iOS中事件的传递和响应者链条
在iOS 开发中,常见的事件有三种类型,分别是: (1)触摸事件:平常手指在屏幕上滑动,产生的事件都是触摸事件 (2)加速计事件:微信的摇一摇就是典型的加速计事件 (3)远程控制事件:耳机控制歌曲上一 ...
- Moq4在.NET3.5和.NET4版本之间的差异
博客搬到了fresky.github.io - Dawei XU,请各位看官挪步.最新的一篇是:Moq4在.NET3.5和.NET4版本之间的差异.
- 第一个java程序
完成自己的第一个java程序 1.新建一个文本文档,在文本文档中编写自己第一个java程序的代码,代码如下; class hello { public static void main(String[ ...
- iOS设计模式之生成器
iOS设计模式之生成器 1.生成器模式的定义 (1): 将一个复杂的对象的构件与它的表示分离,使得相同的构建过程能够创建不同的表示 (2): 生成器模式除了客户之外还包括一个Director(指导者) ...
- Vim 快捷键整理
一.移动光标 1.左移h.右移l.下移j.上移k 2.向下翻页ctrl + f,向上翻页ctrl + b 3.向下翻半页ctrl + d,向上翻半页ctrl + u 4.移动到行尾$,移动到行首0(数 ...
- Hdu 2473(并查集删除操作) Junk-Mail Filter
有木有非常吊 加强 加强版 啊 ,看了都不敢做了 .后来先做了食物链这个我还是看过的.但还是A不掉,没明确神魔意思 .总而言之.大牛的博客是个好东西.我就那么看了一下,还是不懂怎莫办啊,哎, ...