Cond_broadcast和调度顺序
cond_broadcast and scheduling order
我正在写一个生产者/消费者程序。我有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.
听起来,如果一堆因素(调度策略,库版本等)是相同的,那么顺序也会相同。
相关文章:
- CMake-按正确顺序将项目与C运行时对象文件链接
- 函数调用中参数的顺序重要吗
- 如何在c++中实现处理器调度模拟器
- 为什么不;名字在地图上是按顺序排列的吗
- 将Integer转换为4字节的unsined字符矢量(按大端字节顺序)
- 数到第n个楼梯的路(顺序无关紧要)
- 优先顺序:智能指针和类析构函数
- 在循环中按顺序遍历成员变量
- 独立读取-修改-写入顺序
- QML按钮点击功能执行顺序
- C++中数据类型修饰符的顺序
- 当比特(而不是字节)的顺序至关重要时的持久性
- C++从其他 constexpr 创建 lambda 不能按顺序执行 Constexpr
- 通过选项卡的文本设置QTabWidget顺序
- c++11评估顺序(未定义的行为)
- 如何在C++中递归地按相反顺序打印集合
- 给定顺序中的事件处理
- 具有包含其他对象的类的对象创建顺序
- 如何通过替换顺序代码的while循环来添加OpenMP for循环
- Cond_broadcast和调度顺序