等待线程池内线程执行完成的一种方法

本文主要内容:通过AutoResetEvent实现等待线程池内线程执行完成,并进行计时计算。

由于方法比较简单直接贴出代码,如下:

 1 /// <summary>
2 /// 等待线程池内的所有线程执行完成的一种方法
3 /// </summary>
4 public class ExecutedThreadPool
5 {
6 public void ThreadPoolFinish()
7 {
8
9 int iterations = 10;//迭代的次数
10 int doneCount = iterations;//用于AutoResetEvent返回信号量
11 int display = 0;//方便观察结果的数据显示
12 AutoResetEvent done = new AutoResetEvent(false);
13 DateTime startDt = DateTime.Now;//用作时间开始的计时,和最终执行完成多线程的时间比较。目的:验证watcher的时间
14 Stopwatch watcher = Stopwatch.StartNew();
15 for (int i = 0; i < iterations; i++)
16 {
17 ThreadPool.QueueUserWorkItem(r =>
18 {
19 Thread.Sleep(1000);//方便观察时间差
20 Console.WriteLine(string.Format("DateTime:{0},Number:{1}", DateTime.Now, Interlocked.Increment(ref display)));
21 if (Interlocked.Decrement(ref doneCount) == 0)
22 {
23 done.Set();//发出信号量
24 }
25
26 });
27 }
28 done.WaitOne();//阻止当前线程,直到接收到信号量
29 Console.WriteLine(string.Format("Elapsed:{0},Start Time:{1}", watcher.Elapsed, startDt));
30 }
31 }



posted @ 2011-12-16 14:55  走过留痕  阅读(2028)  评论(0编辑  收藏  举报