linux系统编程 信号量 sem系列函数(生产者消费者模型)

信号量是升级的互斥锁,如果多个线程对一个对象的部分数据进行共享,使用互斥锁只能将整个对象锁住,虽然提高了多线程操作的安全性,但导致了并行性的下降,变成串行执行。

生产者消费者模型

生产者生产放入容量为5的队列中等待消费者消费,队列满的话生产者等待消费,队列为空的话消费者等待生产者生产。
定义两个信号量代表现有产品量和队列剩余空位。

#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<fcntl.h>
#include<sys/types.h>
#include<semaphore.h>
#include<pthread.h>
#define NUM 5

int queue[NUM];
sem_t blank_number,product_number;

void *product(void *arg)
{
   
    int i=0;

    while(1)
    {
   
        sem_wait(&blank_number);
        //对应lock,相当于信号量-1操作,如果为0的话就阻塞等待
        //如果队列中有剩余位置(不为0),那么就生产。反之就要等待消费者消费
        
        queue[i]=rand()%1000+1;//模拟生产
        printf("-------------Product----%d\n",queue[i]);
        
        sem_post(&product_number);
        //对应unlock,信号量+1操作,此处代表生产产品+1.

        i=(i+1)%NUM; //模拟环形队列
        sleep(rand()%3);
    }
    return NULL;
}

void *consumer(void *arg)
{
   
    int i
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值