多线程用互斥锁和条件变量实现生产者和消费者-------循环任务队列

互斥锁与条件变量简介

在多线程的环境中,全局变量会被各线程共享,因此在操作全局变量的时候需要采用锁机制,在linux里最常用的锁就是互斥锁,互斥锁使用方法如下

<pre name="code" class="cpp">//线程A
pthread_mutex_lock(&lock);  
...;      //对共享数据操作
pthread_mutex_unlock(&lock);

 这段代码会包括在每一个试图操作共享变量的线程里面,这样就能实现共享变量(临界资源)的互斥使用。 

这样也会遇见一个问题,每个线程在临界资源释放之后都会争夺锁,获得锁的线程会继续执行下去,其他线程都将阻塞在原地直到临界资源被释放后重新争夺锁,这样很容易造成有的线程一直使用锁而有的线程一直抢不到锁,从而造成饿死的现象使程序运行效率十分低下。

为了解决这个问题linux提供了条件变量来使线程之间同步。

条件变量的使用方法如下

<pre name="code" class="cpp">//线程A 
pthread_mutex_lock(&lock); 
if(超前) 
pthread_cond_wait(&不超前,&lock);
 ...; //对共享数据操作 
pthread_mutex_unlock(&lock);

//线程B 
pthread_mutex_lock(&lock); 
if(A不超前) 
pthread_cond_signal(不超前);
 ...; //对共享数据操作 
pthread_mutex_unlock(&lo
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值