多线程编程,条件变量pthread_cond_t应用(转)

#i nclude  <iostream>
#i nclude  <unistd.h>
#i nclude  < pthread.h>
#i nclude  <stdio.h>
using namespace std;
 pthread_mutex_t count_lock;
 pthread_cond_t count_nonzero;
 int  counter =0;
 int estatus=-1;
  void  * decrement_count(void * argv);
  void  * increment_count(void * argv);
int main(int argc, char *argv[])
 printf("counter:%d/n",counter);
 pthread_t thrd1,thrd2;
 int ret;
 ret = pthread_create(&thrd1,NULL,decrement_count,NULL);
 if(ret){
  perror("de1:");
  return 1;
 }
 ret = pthread_create(&thrd2,NULL,increment_count,NULL);
 if(ret){
  perror("in1:");
  return 1;
 }
 int count=0;
 while(count!=20){
  printf("counter:%d/n",counter);
  sleep(1);
  count++;
 }
 return 0;
}
void  * decrement_count (void * argv){
 pthread_mutex_lock(&count_lock);
 while(counter==0)
  pthread_cond_wait(&count_nonzero,&count_lock);
  counter--;
 pthread_mutex_unlock(&count_lock);
 return &estatus;
 
}
 void  * increment_count(void * argv){
 pthread_mutex_lock(&count_lock);
  if(counter==0)
  pthread_cond_signal(&count_nonzero);
 counter++;
 pthread_mutex_unlock(&count_lock);
  return &estatus;

}
如果我们调试程序会发现程序是如下运行的.

开始时 counter 为0,
 ret = pthread_create(&thrd1,NULL,decrement_count,NULL)处生成一个thrd1线程运行decrement_count(),此线程内函数运行流程为:
锁定 互斥锁 count_lock,如果counter为0,此线程被阻塞在 条件 变量count_nonzero上.同时释放互斥锁count_lock.

与此同时主程序还在运行,创建另一个线程thrd2运行 increment_count,此线程内的函数流程如下:
锁定 互斥锁 count_lock,如果counter为0,唤醒在 条件 变量count_nonzero上的线程即thrd1.但是由于有互斥锁count_lock,thrd1还是在等待.然后count++,释放互斥锁,.......thrd1由于互斥锁释放,重新判断counter是不是为0,如果为0再把线程阻塞在 条件 变量count_nonzero上,但这时counter已经为1了.所以线程继续运行.counter--释放互斥锁......
与此主程序间隔打印counter运行一段时间退出.

后记,在编译的时候加上 -lpthread
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值