条件变量和信号量的区别:
(1)使用条件变量**(broadcast**)可以一次唤醒所有等待者,而这个信号量没有的功能,感觉是最大区别。
---------应用场景:当程序退出要唤醒所有线程时,线程池的线程用条件变量;单一线程用信号量;仅有互斥量的线程设置某个线程退出的标志;
(2)信号量是有一个值(状态的),而条件变量是没有的,没有地方记录唤醒(发送信号)过多少次,也没有地方记录唤醒线程(wait返回)过多少次。
信号量由于把信号值+1,就不管了;
而条件变量是singnal一个等待的线程,如果没有线程等待,就会出现唤醒丢失。所以信号量可以解决条件变量中存在的唤醒丢失问题。-----------
(3)在Posix.1基本原理一文声称,有了互斥锁和条件变量还提供信号量的原因是:“本标准提供信号量的而主要目的是提供一种进程间同步的方式;这些进程可能共享也可能不共享内存区。互斥锁和条件变量是作为线程间的同步机制说明的;这些线程总是共享(某个)内存区。这两者都是已广泛使用了多年的同步方式。每组原语都特别适合于特定的问题”。尽管信号量的意图在于进程间同步,互斥锁和条件变量的意图在于线程间同步,但是信号量也可用于线程间,互斥锁和条件变量也可用于进程间。应当根据实际的情况进行决定。信号量最有用的场景是用以指明可用资源的数量。
经典的一句话:
互斥量是信号量的一种特例,互斥量的本质是一把锁。A mutex is basically a lock that we set (lock) before accessing a shared resource and release (unlock) when we’re done
锁和条件变量、信号量
条件变量和锁
条件变量和锁:
pthread_cond_wait指的是条件变量,总和一个互斥锁结合使用。在调用pthread_cond_wait前要先获取锁。pthread_cond_wait函数执行时先自动释放指定的锁,然后等待条件变量的变化。在函数调用返回之前,自动将指定的互斥量重新锁住。
int pthread_cond_signal(pthread_cond_t * cond);pthread_cond_signal通过条件变量cond发送消息,若多个消息在等待,它只唤醒一个。
pthread_cond_broadcast可以唤醒所有。调用pthread_cond_signal后要立刻释放互斥锁,因为pthread_cond_wait的最后一步是要将指定的互斥量重新锁住,如果pthread_cond_signal之后没有释放互斥锁,pthread_cond_wait仍然要阻塞。
无论哪种等待方式,都必须和一个互斥锁配合,以防止多个线程同时请求pthread_cond_wait()(或pthread_cond_timedwait(),下同)的竞争条件(Race
Condition)。mutex互斥锁必须是普通锁(PTHREAD_MUTEX_TIMED_NP)或者适应锁
(PTHREAD_MUTEX_ADAPTIVE_NP)