设置缓冲区和调用pthread_cond_signal时是否需要设置mutexlock / unlock

问题描述 投票:0回答:1

有两个线程。 No.1是生产者,No.2是消费者 1和2线程正在使用相同的缓冲区。

我想知道是否需要在1号线程上设置Mutex锁定/解锁。 你能指导一下吗?

1号

{

 /*[Need here Mutex lock? pthread_mutex_loc(&mut);]*/

 setting_buffer();

 pthread_cond_signal(&cond);

 /*[Need here Mutex unLock? pthread_mutex_unlock(&mut);]*/

}

2号

{

 pthread_mutex_loc(&mut);

 pthread_cond_wait(&cond, &mut);


 consumming_buffer();


 pthread_mutex_unlock(&mut);

}
c pthreads mutex condition-variable
1个回答
0
投票

是的,您需要在信令/缓冲区设置端的某处锁定互斥锁。

条件变量必须始终与等待线程等待的共享状态的某些条件配对 - 这就是它被称为条件变量的原因。在pthread_cond_wait()返回后,等待方必须始终重新检查它正在等待的条件 - 即使它尚未发出信号,也可以提前返回。在几乎所有情况下,这意味着您应该在检查条件的循环中调用pthread_cond_wait()

pthread_mutex_lock(&mut);

while (!buffer_is_set())
    pthread_cond_wait(&cond, &mut);

consume_buffer();

pthread_mutex_unlock(&mut);

buffer_is_set()条件必然会查看另一个线程正在更新的某个共享状态,因此另一个线程还必须锁定互斥锁以防止对该状态的竞争访问:

 pthread_lock(&mut);

 setting_buffer(); /* Now buffer_is_set() will return true */

 pthread_cond_signal(&cond);

 pthread_unlock(&mut);

请注意,互斥锁只需要锁定在setting_buffer()调用周围 - 解锁互斥锁后可以安全地调用pthread_cond_signal()

© www.soinside.com 2019 - 2024. All rights reserved.