先看一段小小的伪代码
int x,y;
pthread_mutex_t mut = PTHREAD_MUTEX_INITIALIZER;
pthread_cond_t cond = PTHREAD_COND_INITIALIZER;
线程一:
pthread_mutex_lock(&mut);
while (x <= y)
{
pthread_cond_wait(&cond, &mut);
}
pthread_mutex_unlock(&mut);
线程二:
pthread_mutex_lock(&mut);
if (x > y)
pthread_cond_broadcast(&cond);
pthread_mutex_unlock(&mut);
三步理解
第一步:
通过这个例子pthread_cond_wait()的作用很简单。如果while(X<=Y)成立,则执行pthread_cond_wait()函数(释放互斥锁mut,然后挂起线程一,线程一就想阻塞在pthread_cond_wait()函数这里,等待被唤醒)。
第二步:
因为pthread_cond_wait()函数可以释放锁mut,所以第二个线程可以获得锁,得以执行线程接下来的程序。
直到第二个线程,X>Y成立后,执行pthread_cond_broadcast(&cond),然后这个线程一就会被唤醒。由于pthread_cond_broadcast(&cond)下一句就是pthread_mutex_unlock(&mut);所以在下一句中释放互斥量mut。
第三步:
然后第一个线程开始从pthread_cond_wait()执行,唤醒后会再次锁mut , 如果锁成功,再进行条件的判断 (至于为什么用WHILE,即在被唤醒之后还要再判断,后面在补充解释),如果满足条件,则被唤醒 进行处理,最后释放互斥量mut。
补充解释:
为什么要用while作重复判断?
因为实际情况下,有可能是多一个线程都在等待这个条件,但我们只需要一个线程进行处理,此时就必须要再次条件判断,以保证只有一个线程进入临界区处理。 这样就可以起到同步的作用。
总结:
pthread_cond_wait() 用于挂起当前线程并线程会堵塞在当前阶段不会往下走,同时释放互斥锁。
在别的线程使用 pthread_cond_signal() 或pthread_cond_broadcast来唤醒后,pthread_cond_wai)