信号量是升级的互斥锁,如果多个线程对一个对象的部分数据进行共享,使用互斥锁只能将整个对象锁住,虽然提高了多线程操作的安全性,但导致了并行性的下降,变成串行执行。
生产者消费者模型
生产者生产放入容量为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