Msky()是否将周期分配给其他线程?

2022-05-23 00:00:00 sleep c++

在多线程应用程序中,是

while (result->Status == Result::InProgress) Sleep(50);
//process results

优于

while (result->Status == Result::InProgress);
//process results

? 通过这一点,我在问,第一种方法会在等待结果的同时礼貌地对待其他线程,而不是不停地旋转吗?我等待的操作通常需要大约1-2秒,并且位于不同的线程上。


解决方案

好多了,但好不了多少。

只要result->Status不是volatile,允许编译器缩减

while(result->Status == Result::InProgress);

if(result->Status == Result::InProgress) for(;;) ;

因为循环内部的条件没有更改。

调用外部(因此隐式volatile)函数Sleep会改变这一点,因为这可能会修改result结构,除非编译器知道Sleep从不修改数据。因此,根据编译器的不同,第二个实现进入无限循环的可能性要小得多。

也不能保证对result->Status的访问将是原子的。对于特定的内存布局和处理器体系结构,读写此变量可能包括多个步骤,这意味着调度器可能决定介入中间。

因为此时您所通信的只是一个简单的是/否,并且接收线程也应该等待否定的回复,所以最好的方法是使用您的操作系统提供的适当的线程同步原语来实现这一效果。这样做的好处是,当条件发生变化时,您的线程会立即被唤醒,并且在此期间它不使用CPU,因为操作系统知道您的线程正在等待什么。

在Windows上,使用CreateEvent和co。若要使用事件对象进行通信,请在Unix上使用pthread_cond_t对象。

相关文章