本篇文章是对生产者与消费者队列进行了详细的分析介绍,需要的朋友参考下
上次我们使用AutoResetEvent实现了一个生产/消费者队列。这一次我们要使用Wait和Pulse方法来实现一个更强大的版本,它允许多个消费者,每一个消费者都在自己的线程中运行。
我们使用数组来跟踪线程。
Thread[] _workers;
通过跟踪线程可以让我们在所有的线程都结束后再结束我们的队列任务。
每一个消费者线程都执行一个叫做Consume的方法,在一个for循环中,我们可以创建和启动线程。例如:
public PCQueue(int workerCount)
{
_workers = new Thread[workerCount];
for (int i = 0; i
}
上次我们使用的是一个字符串来代表任务,这次我们使用Action委托,它的定义如下:
Public delegate void Action();
为了表示一系列的任务,我们使用Queue
Queue
在我们调用生产(EnqueueItem)和消费(Consume)方法前,还是完整的看一看代码吧:
class PCQueue
{
readonly object _locker = new object();
Thread[] _workers;
Queue
public PCQueue(int workerCount)
{
_workers = new Thread[workerCount];
for (int i = 0; i
}
public void Shutdown(bool waitForWorkers)
{
//为每一个线程插入一个null item,可以是每一个worker 退出
foreach (Thread worker in _workers)
EnqueueItem(null);
//等待所有的线程退出。
if (waitForWorkers)
foreach (Thread worker in _workers)
worker.Join();
}
public void EnqueueItem(Action item)
{
lock (_locker)
{
_itemQ.Enqueue(item);
Monitor.Pulse(_locker); //通知等待队列中的线程
}
}
void Consume()
{
while (true)
{
Action item;
lock (_locker)
{
while (_itemQ.Count == 0)
{
Monitor.Wait(_locker); //释放锁,并阻止当前线程,直到其他线程发送pulse信号。 }
item = _itemQ.Dequeue();
}
if (item == null) return; //退出的信号
item();
}
}
}
以上就是深入多线程之:深入生产者、消费者队列分析的详细内容,更多请关注0133技术站其它相关文章!