Cond_broadcast和调度顺序

cond_broadcast and scheduling order

本文关键字:调度 顺序 broadcast Cond      更新时间:2023-10-16

我正在写一个生产者/消费者程序。我有3个消费者从队列中读取数据,一个生产者在队列中写入数据。当生产者在队列中写入内容时,它使用phtread_cond_broadcast广播它。然后消费者觉醒了,但我在我的节目中找到了一种模式。其中一个消费者总是在其他人之前唤醒,然后清除队列。我的问题是广播每次以相同的顺序唤醒所有线程是正常的吗?

制作人:

pthread_mutex_lock(&mutex1);
if(/* write something */)
phtread_cond_broadcast(&cond1)
pthread_mutex_unlock(&mutex1);
消费者:

pthread_mutex_lock(&mutex1);
while(/* queue vide */)
phtread_cond_wait(&cond1);
pthread_mutex_unlock(&mutex1);

如果在生产者写入内容时只有一个消费者可能有工作要做,那么您应该考虑使用pthread_cond_signal()。这样,您将只唤醒一个(注意,根据文档,它可能不止一个),而不是所有的消费者。唤醒他们所有人会导致"雷鸣般的羊群"现象,在这种情况下,每个人都急于抓住相同的工作项,然后他们中的大多数人什么也没做就回去睡觉了。

根据手册If more than one thread is blocked on a condition variable, the scheduling policy determines the order in which threads are unblocked.

听起来,如果一堆因素(调度策略,库版本等)是相同的,那么顺序也会相同。