提升进程间互斥和条件变量

时间:2018-04-25 16:06:35

标签: c++ boost mutex boost-interprocess

我正在查看这个Boost示例代码,看看它们之间共享互斥和条件变量的两个进程:

https://www.boost.org/doc/libs/1_57_0/doc/html/interprocess/synchronization_mechanisms.html

但我不明白这里的互斥条件变量设计是如何工作的。

初始流程调用:

for(int i = 0; i < NumMsg; ++i){
     scoped_lock<interprocess_mutex> lock(data->mutex);    // Take mutex
     if(data->message_in){
        data->cond_full.wait(lock);                        // Wait
     }
     if(i == (NumMsg-1))
        std::sprintf(data->items, "%s", "last message");
     else
        std::sprintf(data->items, "%s_%d", "my_trace", i);

     //Notify to the other process that there is a message
     data->cond_empty.notify_one();                        // Notify

     //Mark message buffer as full
     data->message_in = true;
  }

并且第二个进程调用:

  bool end_loop = false;
  do{
     scoped_lock<interprocess_mutex> lock(data->mutex);     // Take mutex
     if(!data->message_in){
        data->cond_empty.wait(lock);                        // Wait
     }
     if(std::strcmp(data->items, "last message") == 0){
        end_loop = true;
     }
     else{
        //Print the message
        std::cout << data->items << std::endl;
        //Notify the other process that the buffer is empty
        data->message_in = false;
        data->cond_full.notify_one();                       // Notify         
     }
  }
  while(!end_loop);

要致电wait()notify(),任何一个进程都必须保留共享的互斥锁,因此如果一个进程在wait(),另一个进程肯定无法调用notify()

1 个答案:

答案 0 :(得分:2)

在等待时等待释放互斥锁,因此另一个线程可以获取互斥锁并执行通知。 另请参阅https://www.boost.org/doc/libs/1_57_0/doc/html/interprocess/synchronization_mechanisms.html#interprocess.synchronization_mechanisms.conditions.conditions_whats_a_condition上的说明。