生产者消费者算法的实现

生产者消费者算法是经典的进程同步算法,下面就是运用C++模拟实现生产者消费者算法,能实现对缓冲池的互斥访问和生产者进程与消费者进程之间的同步。

实现思路:用C++写一个生产者和消费者类,在里面有一个构造函数,初始化指向产品的指针,产品数和互斥信号量mutex(互斥访问count),接下来就写了生产者和消费者算法,这里要注意的是:缓冲区满时不能生产,缓冲区空时不能消费,这里我都在运行中有提示。主函数中就是循环调用生产者消费者,然后每次调用后输出缓冲区的产品状态和数量。

源代码:

#include <iostream>
#include <time.h>
#include <stdlib.h>
#define N 100	//产品数量
using namespace std;

/*生产者消费者类*/
class PandC{
private:
	int in,out;//指向有产品的下标
	int count;//缓冲区的产品数
	int buffer[N];//缓冲区
	int mutex;//互斥信号量
	int  empty,full;//判断缓冲区是否为空或者满
public:
	/*初始化,构造生产者消费者*/
	PandC(){
		in=0;out=0;count=0;
		empty=N;full=0;mutex=1;
		for(int i=0;i<N;i++)
			buffer[i]=0;
	}

	/*生产者生产*/
	void Producer(){
		if(empty==0){
			full=1;
			cout<<"产品已满,不能再生产"<<endl;
			return ;
		}
		Wait(empty);//empty--;
		
		buffer[out]=1;	//生产一个产品
		out=(out+1)%N;	//尾指针后移一位,构成循环队列

		cout<<"生产者生产了一个产品"<<endl;	

		/*对count互斥访问*/
		Wait(mutex);
		count++;
		Signal(mutex);
	}

	/*消费者消费*/
	void Consumer(){
		if(empty==N){
			cout<<"没有产品,不能消费"<<endl;
			return ;
		}
	
		buffer[in]=0;//消费一个产品
		in=(in+1)%N;//头指针后移一位,构成循环队列

		cout<<"消费者消费了一个产品"<<endl;
		
		/*对count互斥访问*/
		Wait(mutex);
		count--;
		Signal(mutex);

		if(empty<=N){
			full=0;
			Signal(empty);//empty++;
		}
	}
	
	/*显示现在缓冲区的情况*/
	void Display(){
		for(int i=0;i<N;i++)
			cout<<buffer[i];
		cout<<endl<<"一共有"<<count<<"个产品"<<endl<<endl;
	}
	
	void Wait(int &s){
		if(s<=0) return ;
		s--;
	}

	void Signal(int &s){
		s++;
	}

};

int main(){
	int i=0;
	srand(time(NULL));
	PandC x;

	/*随机执行生产者生产还是消费者消费*/
	do{
	if(rand()%100>80)//利用比例控制生产速度
		x.Producer();
	else
		x.Consumer();
	x.Display();
	i++;
	}while(i!=1000);

	return 0;
}

简单实现了生产者消费者算法,用0,1表示有没有产品,还是过于抽象了,如果能用进度条那种形式就更好了,但是能力有限,只是实现了其中的算法思想,还是需要学习,改进。

  • 7
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
生产者消费者算法是一种用于解决多线间数据共享和同步的经典问题。下面是一个简单的生产者消费者算法的代码实现: ```python import threading import time import random # 共享的缓冲区 buffer = [] buffer_size = 5 # 互斥锁和条件变量 mutex = threading.Lock() not_full = threading.Condition(mutex) not_empty = threading.Condition(mutex) # 生产者线程 class Producer(threading.Thread): def run(self): global buffer while True: mutex.acquire() while len(buffer) == buffer_size: print("缓冲区已满,生产者等待...") not_full.wait() item = random.randint(1, 10) buffer.append(item) print("生产者生产了一个物品:", item) not_empty.notify() mutex.release() time.sleep(random.random()) # 消费者线程 class Consumer(threading.Thread): def run(self): global buffer while True: mutex.acquire() while len(buffer) == 0: print("缓冲区为空,消费者等待...") not_empty.wait() item = buffer.pop(0) print("消费者消费了一个物品:", item) not_full.notify() mutex.release() time.sleep(random.random()) # 创建生产者消费者线程并启动 producer = Producer() consumer = Consumer() producer.start() consumer.start() ``` 上述代码中,生产者线程不断地向缓冲区中添加物品,如果缓冲区已满,则生产者线程等待。消费者线程不断地从缓冲区中取出物品,如果缓冲区为空,则消费者线程等待。通过互斥锁和条件变量的配合,实现生产者消费者之间的同步和互斥。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值