首页 > 编程语言 > 详细

我对线程条件变量的初步探究

时间:2014-03-14 00:05:22      阅读:599      评论:0      收藏:0      [点我收藏+]

下面这份代码是我的书写方式:

static bool alive = true;

static int count = 0;

pthread_mutex_t mutex;

pthread_cond_t cond;


void producer()

{

      pthread_mutex_lock(&mutex);  //加互斥锁

      //...do something here, queue.insert() ...or create something...

      count++;

     

     //如果像下面这样写,则consumer阻塞到pthread_mutex_lock(&mutex)

     //比pthread_cond_wait(&cond, &mutex)先得到互斥锁控制权。

      pthread_mutex_unlock(&mutex); //解互斥锁

      pthread_cond_signal(&cond);  //唤醒wait(),如果没有wait则什么都不做


     //如果像下面这样写,则consumer阻塞到pthread_mutex_lock(&mutex)

     //比pthread_cond_wait(&cond, &mutex)可能后得到互斥锁控制权。

      pthread_cond_signal(&cond);  //唤醒wait(),如果没有wait则什么都不做

      pthread_mutex_unlock(&mutex); //解互斥锁

}

void consumer()

{

      pthread_mutex_lock(&mutex);//加互斥锁

      while(alive && 0 == count) {   //仅在count == 0 时才wait,而且是while()不是if(),经过测试必须得是while,why?

//因为pthread_cond_wait(&cond, &mutex)分为unlock-》wait-》lock,当像producer像第一种书写顺序,则即使得到signal,

//那么无法获得互斥锁控制权,那么将阻塞在lock上,相当于回退2行到  pthread_mutex_lock(&mutex);

            pthread_cond_wait(&cond, &mutex);  //内部先解互斥锁才睡眠,等唤醒后自动加回互斥锁。

      }

      //... do something here, queue.get() ... or use & delete something

      count --;

      pthread_mutex_lock(&mutex);//解互斥锁

}转载请注明出处,谢谢: http://blog.csdn.net/sprintfwater/article/details/21190859

我对线程条件变量的初步探究,布布扣,bubuko.com

我对线程条件变量的初步探究

原文:http://blog.csdn.net/sprintfwater/article/details/21190859

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