pthread_cond_wait()是linux多线程同步实现的一种方法,表示等待某一个线程共享变量满足了某种情况时
线程才能继续执行 pthread_cond_wait()之后的代码,如下面的示例代码段所示,thread_func()函数中的代码
示例是一种比较常见的等待共享变量的方式,这里主要关注 while(head == NULL)的使用
 
struct xxx* head; /** 全局线程共享变量*/
pthread_mutex_t mtx = PTHREAD_MUTEX_INITIALIZER; /** 为条件变量搭配的互斥锁*/
pthread_cond_t cond = PTHREAD_COND_INITIALIZER; /** 定义全局线程共享的条件变量*/ staticvoid* thread_func(void*arg)
{
/** 首先先获得互斥锁,表示同一时间只能有一个线程等待条件变量
* 如果没有保持只有一个线程监听条件变量的话,那有可能会引起线程的"惊群"现象
*/
pthread_mutex_lock(&mtx); /** 下面理解为什么需要先判断 head == NULL 的值(假设这里就是需要等待 head == NULL )
* 根据pthread相关文档理解: 假设线程1执行到pthread_cond_wait()时,首先线程释放mtx互斥锁,
* 之后再开始等待pthread_cond_signal()或者pthread_cond_broadcast()发送过来的"条件满足信号"
* 假如这时候某另外的一个线程2获得了mtx锁并改变head的值,使得head == NULL 并发送了信号且
* 完成之后释放了mtx锁, 这时候可能系统存在线程3正在等待获得互斥锁,那么现在有两种情况:1.线程3
* 获得锁,之后对head进行了一些操作,之后可能发送了信号,再释放了互斥锁;2.线程1获得了互斥
* 锁mtx,那么这时候线程1继续原来等待的逻辑,由于等待时释放了锁,现在需要重新获得这种情况也获得了,
* 这时候程序执行while(head == NULL)的判断,ok, 现在能明白为什么这里需要判断 head == NULL ?了,因为在
* 上面情况1中线程3比线程1可能更早一步获得锁之后对head操作并使得head != NULL ,事实上大型的系统可能会有更多
* 的线程同时在竞争一个互斥锁,对于共享变量值的改变可能会有更多的情况,也就是说线程1进入等待之后释放锁,
* 直到收到唤醒信号, 在去重新获得锁的过程中,不一定能在收到信号后作为第一个获得锁的线程,也就是在获得锁时
* 其他线程可能获得锁并改变了head的值,比如上面例子尽管线程2在head == NULL 时发出了信号。
* 线程1判断head == NULL是否满足,如果不满足条件,则重新释放mtx锁,并进入信号等待的过程,重复上面唤醒的逻辑
* 直到 head == NULL 时,程序执行之后的逻辑,最后释放mtx互斥锁
*/
while(head != NULL)
{
pthread_cond_wait(&cond, &mtx);
} /** head == NULL 时执行的逻辑*/
... pthread_mutex_unlock(&mtx);//临界区数据操作完毕,释放互斥锁 return0;
}
 以上所说的信号,并不是只unix/linux 信号量或者系统信号的概念,仅仅代表一种线程唤醒的通信方式

关于pthread_cond_wait()使用的理解的更多相关文章

  1. pthread_cond_wait()函数的理解(摘录)

    /************pthread_cond_wait()的使用方法**********/pthread_mutex_lock(&qlock);    /*lock*/pthread_c ...

  2. 深入理解pthread_cond_wait、pthread_cond_signal

    ===============================man pthread_cond_wait的解释========================== LINUX环境下多线程编程肯定会遇到 ...

  3. linuxc线程信号-pthread_cond_wait理解

    pthread_cond_wait(pthread_cond_t *cond, pthread_mutex_t*mutex)函数 传入的參数mutex用于保护条件,由于我们在调用pthread_con ...

  4. 关于pthread_cond_wait使用while循环判断的理解

    在Stevens的<Unix 环境高级编程>中第11章线程关于pthread_cond_wait的介绍中有一个生产者-消费者的例子P311,在进入pthread_cond_wait前使用w ...

  5. pthread_cond_wait的原子性

    使用的基本模板如下(参考APUE): signal代码序列如下, pthread_mutex_lock ... pthread_cond_signal pthread_mutex_unlock   w ...

  6. 深入理解 iOS 开发中的锁

    来源:伯乐在线 - 夏天然后 链接:http://ios.jobbole.com/89474/ 点击 → 申请加入伯乐在线专栏作者 摘要 本文的目的不是介绍 iOS 中各种锁如何使用,一方面笔者没有大 ...

  7. 理解 Linux 条件变量

    理解 Linux 条件变量 1 简介 当多个线程之间因为存在某种依赖关系,导致只有当某个条件存在时,才可以执行某个线程,此时条件变量(pthread_cond_t)可以派上用场.比如: 例1: 当系统 ...

  8. 互斥量、条件变量与pthread_cond_wait()函数的使用,详解(一)

    1. 首先pthread_cond_wait 的定义是这样的 The pthread_cond_wait() and pthread_cond_timedwait() functions are us ...

  9. pthread_cond_wait()函数的详解

    http://hi.baidu.com/tjuer/item/253cc6d66b921317d90e4483 了解 pthread_cond_wait() 的作用非常重要 -- 它是 POSIX 线 ...

随机推荐

  1. VS2012快捷键突然不能用怎么办

    晚上做项目做着做着,就去弄了下键盘配置,可怜的娃娃~~~一下子弄得什么快捷键都不能用了,比如”注释:ctrl+k ctrl+c”;问题纠结了我一个多钟,好在最后结合了网络上各路英雄的idea;解决了问 ...

  2. tomcat 的最大连接数设置

    前提说明为了确保服务不会被过多的http长连接压垮,我们需要对tomcat设定个最大连接数,超过这个连接数的请求会拒绝,让其负载到其它机器.达到保护自己的同时起到连接数负载均衡的作用. 动手去做一开始 ...

  3. Python: attrgetter()函数: 排序不支持原生比较的对象

    问题: 想排序类型相同的对象,但是他们不支持原生的比较操作. answer: 内置的sorted()函数有一个关键字参数key,可传入一个callable对象给它 这个callabel对象对每个传入的 ...

  4. java后台获取和js拼接展示信息

    java后台获取和js拼接展示信息: html页面代码: <div class="results-bd"> <table id="activityInf ...

  5. mysql count group by统计条数方法

    mysql count group by统计条数方法 mysql 分组之后如何统计记录条数? gourp by 之后的 count,把group by查询结果当成一个表再count一次select c ...

  6. Ajax jquery的库的简化版本

    Ajax jquery的库的简化版本 (function(){    //面向外界的唯一变量接口!    var myajax = window.myajax = {};    //作者.版本号等等信 ...

  7. JavaScript中几种 获取元素的方式

    1.根据id获取元素 document.getElementById("id属性的值"); 2.根据标签名字获取元素 document.getElementsByTagName(& ...

  8. 关于windows下c++生成的exe发布时的依赖dll问题

    如同linux下通常要求安装特定版本的libstdc++一样,windows下vc++生成的exe发布时的依赖dll问题,可以参见帖子,http://bbs.csdn.net/topics/39105 ...

  9. npm 查看全局安装过的包

    查看全局安装的包 npm list -g --depth 0 非全局安装的包 npm list --depth 0 如果不加参数 --depth 0会显示安装的包以及相关的依赖包,会显示的很详细.

  10. 20135234mqy-——信息安全系统设计基础第五周学习总结

    程序的机器级表示 3.1 intel处理器系列俗称x86,经历了一开始个长期的,不断进化的发展过程. 开始时它是第一代单芯片,16位微处理器之一,由于当时集成电路技术水性有限,其中做了很多妥协,此后, ...