mutex的问题用法分析总结.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
mutex的问题用法分析总结

pthread_cond_wait 、mutex的问题用法分析总结 条件变量: 条件变量是利用线程间共享的全局变量进行同步的一种机制,主要包括两个动作:一个线程等待条件变量的条件成立而挂起;另一个线程使条件成立(给出条件成立信号)。为了防止竞争,条件变量的使用总是和一个互斥锁结合在一起。 1. 创建和注销 条件变量和互斥锁一样,都有静态动态两种创建方式,静态方式使用PTHREAD_COND_INITIALIZER常量,如下: pthread_cond_t cond PTHREAD_COND_INITIALIZER 动态方式调用pthread_cond_init 函数,API定义如下: int pthread_cond_init pthread_cond_t *cond, pthread_condattr_t *cond_attr 尽管POSIX标准中为条件变量定义了属性,但在LinuxThreads中没有实现,因此cond_attr值通常为NULL,且被忽略。 注销一个条件变量需要调用pthread_cond_destroy ,只有在没有线程在该条件变量上等待的时候才能注销这个条件变量,否则返回EBUSY。因为Linux实现的条件变量没有分配什么资源,所以注销动作只包括检查是否有等待线程。API定义如下: int pthread_cond_destroy pthread_cond_t *cond 2. 等待和激发 Int pthread_cond_wait pthread_cond_t *cond, pthread_mutex_t *mutex int pthread_cond_timedwait pthread_cond_t *cond, pthread_mutex_t *mutex, const struct timespec *abstime 等待条件有两种方式:无条件等待pthread_cond_wait 和计时等待pthread_cond_timedwait ,其中计时等待方式如果在给定时刻前条件没有满足,则返回ETIMEOUT,结束等待,其中abstime以与time 系统调用相同意义的绝对时间形式出现,0表示格林尼治时间1970年1月1日0时0分0秒。 无论哪种等待方式,都必须和一个互斥锁配合,以防止多个线程同时请求pthread_cond_wait (或pthread_cond_timedwait ,下同)的竞争条件(Race Condition)。mutex互斥锁必须是普通锁(PTHREAD_MUTEX_TIMED_NP)或者适应锁(PTHREAD_MUTEX_ADAPTIVE_NP),且在调用pthread_cond_wait 前必须由本线程加锁(pthread_mutex_lock ),而在更新条件等待队列以前,mutex保持锁定状态,并在线程挂起进入等待前解锁。在条件满足从而离开pthread_cond_wait 之前,mutex将被重新加锁,以与进入pthread_cond_wait 前的加锁动作对应。 激发条件有两种形式,pthread_cond_signal 激活一个等待该条件的线程,存在多个等待线程时按入队顺序激活其中一个;而pthread_cond_broadcast 则激活所有等待线程。 #include #include static pthread_mutex_t mtx PTHREAD_MUTEX_INITIALIZER; static pthread_cond_t cond PTHREAD_COND_INITIALIZER; struct node int n_number; struct node *n_next; *head NULL; /*[thread_func]*/ static void cleanup_handler void *arg printf Cleanup handler of second thread.\n ; free arg ; void pthread_mutex_unlock mtx ; static void *thread_func void *arg struct node *p NULL; pthread_cleanup_push cleanup_handler, p ; while 1 pthread_mutex_lock mtx ; //这个mutex主要是用来保证pthread_cond_wait的并发性 while head NULL //这个while要特别说明一下,单个pthread_cond_wait功能很完善

文档评论(0)

kaiss + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档