生产者与消费者c语言
① 简单的“生产者-消费者”问题 请用c语言编写
int mutex=1 ,Vm=10 , vn=0;int in=0;int out=0; while (1)/*生产者进程*/{ { 生产下一个产品 } P(M) P(mutex) buffer[in]=proct in=(in+1) %10 V(mutex) V(N)} while(1) //消费者进程{ P(N); p(mutex); goods=buffer[out]; out=(out+1)%10; V(mutex); V(M);}
② 谁会用C语言编写生产者与消费者问题
呵呵 !
不知道我这样的理解对不对!!!
程序如下,你看看吧.
#include "windows.h"
#include "conio.h"
#include "stdio.h"
#define MAX 20 //定义缓冲池的最大容量是20
int count=5; //初始产品的数量为5
void Proclucer()//生产者函数
{
while(1)
{
if(count >= MAX)
{
printf("缓冲池已满!等待 1 秒!\n");
Sleep(3000);
}
else
{
count++;
printf("生产了一个产品!当前产品的数量是: %d \n\n",count);
Sleep(1300); //注意毫秒为单位
}
}
}
void Consumer() //消费者函数
{
while(1)
{
if(count == 0)
{
printf("缓冲池已空!等待 2 秒!\n");
Sleep(2000);
}
else
{
count--;
printf("取出了一个产品!当前产品的数量是: %d \n\n",count);
Sleep(1000);
}
}
}
int tStop() //停止函数
{
getch(); //如果按回车的话,有时候要按两次才可以停止,我还没有解决这个问题
return 11; //但是按其他按键就会立即停止的了 呵呵!
}
void Start() //开始函数
{
int m;
HANDLE ahThread=CreateThread(NULL,0,(LPTHREAD_START_ROUTINE)Proclucer,NULL,0,NULL);
HANDLE bhThread=CreateThread(NULL,0,(LPTHREAD_START_ROUTINE)Consumer,NULL,0,NULL);
HANDLE hThread=CreateThread(NULL,0,(LPTHREAD_START_ROUTINE)tStop,NULL,0,NULL); //多线程
m=tStop();
if(m==11) //满足停止条件
{
CloseHandle(ahThread);
CloseHandle(ahThread);
CloseHandle(hThread);
printf("\nClose Thread Success!\n"); //停止成功
}
}
void main() //主函数
{
Start(); //开始
printf("\n");
}
③ 生产者-消费者”问题 用C语言编写
#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<semaphore.h>
#include<pthread.h>
#definePRODUCER10//生产者数量
#defineCONSUMER8//消费者数量
#defineBUFFER20//缓冲区数量
sem_tempty,full;//同步信号量
pthread_mutex_tmutex;//互斥信号量
intbuffer[BUFFER];//缓冲区
intprocer_id=0,consumer_id=0;//生产者消费者ID
intindex_in=0,index_out=0;//生产者消费者存放消费的位置
voidprint()//输出缓冲区
{
inti;
printf("Buffer: ");
for(i=0;i<20;i++)
{
printf("___");
}
printf(" ");
for(i=0;i<20;i++)
printf("|%d|",buffer[i]);
printf(" ");
for(i=0;i<20;i++)
{
printf("———");
}
printf(" ");
}
void*Procer()//生产者函数
{
intID=++procer_id;
while(1)
{
sleep(3);
sem_wait(&empty);
pthread_mutex_lock(&mutex);
index_in=index_in%BUFFER;
printf("Procer%din%d. ",ID,index_in);
buffer[index_in]=1;//缓冲区置0
print();//输出缓冲区情况
index_in++;
pthread_mutex_unlock(&mutex);
sem_post(&full);
}
}
void*Consumer()//消费者函数
{
intID=++consumer_id;
while(1)
{
sleep(3);
sem_wait(&full);
pthread_mutex_lock(&mutex);
index_out=index_out%BUFFER;
printf("