首页 > 其他 > 详细

pthread_cond_broadcast用处

时间:2014-06-12 21:22:05      阅读:700      评论:0      收藏:0      [点我收藏+]

以前学习POSIX THREAD时就不太理解broadcast在什么场景下使用比较合适。因为broadcast的语义是唤醒所有被阻塞的线程。

当时的想法是,在系统析构时调用它比较有效,唤醒阻塞的线程,回收线程资源,然后退出系统。

 

今天在做 lock_server 时,才了解到broadcast的用处,它的效果是,减少系统中条件变量的个数

 

需求

系统中有很多锁,锁有FREE和LOCKED两种状态。不同的client会申请自己需要的锁,server响应client的申请。假如client申请的锁已被占用,那么client应该阻塞,等待锁被释放。

设计1 

client阻塞在它需要的那个锁上,应该是pthread_cond_wait(&lockid, &mutex)

这样设计的话,对于每一个锁,都需要一个对应的条件变量,这样设计增加了系统的复杂性

设计2 应用broadcast

系统中设置一个共享的条件变量 cond,所有的线程阻塞在cond上

1
2
3
4
while(lock_status_[lid] == LOCKED) {
    pthread_cond_wait(&c_, &m_);
}  
    pthread_cond_broadcast(&c_);   

这样,一旦某个锁被释放,所有的阻塞线程都会被唤醒,但唯有阻塞在这个锁的线程才能真正被唤醒。

另外,mutex的使用,保证了最多一个线程被真正唤醒,即便是broadcast。

 

pthread_cond_broadcast用处,布布扣,bubuko.com

pthread_cond_broadcast用处

原文:http://www.cnblogs.com/zhouzhuo/p/3781511.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!