C++多线程之生产者-消费者模型

/**
 * 生产者-消费者模型
 * 定义一个产品类型,和产品仓库,定义生产者和消费者
 * 生产者生产产品并存入仓库,消费者从仓库取出产品并消耗
 * 仓库满时,生产者停止生产,仓库空时,消费者停止消费
 * 存入产品时计数加一,取出产品时计数减一
 * 生产和消费需要时间
 */
#include <iostream>
#include <condition_variable>
#include <mutex>
#include <thread>
#include <chrono>
#include <queue>
#include <atomic>

using namespace std;

//定义任意一个产品类型
struct Product {
	int prod_value;
};

const int MAX_SIZE = 10; //仓库最大容量
queue<Product> ware_house; 

std::atomic<int> prod_index = 0; //产品编号
std::atomic<int> prod_count = 0; //仓库产品数量

mutex condition_mutex; //仓库互斥量
condition_variable produce_buffer; //条件变量

bool is_producing{ true };
bool is_consuming{ true };

void Producer(const int producer_time) {
	while (is_producing) {

		prod_index++;
		Product prod{ prod_index }; //准备产品

		//创建信号量,对资源加锁
		unique_lock<mutex> lk(condition_mutex);
		produce_buffer.wait(lk, [] {                   //条件变量等待信号,阻塞线程
			return prod_count < MAX_SIZE;              //满足期望时返回
		});
		
		//获得仓库所有权,产品放入仓库
		ware_house.push(prod);
		prod_count++;
		cout << "Producer --> product " << prod_index  
			 << " inventory " << prod_count << endl;

		produce_buffer.notify_all(); //通知所有等待的条件变量
		lk.unlock(); //解除对资源的锁定

		//生产技能冷却
		std::this_thread::sleep_for(std::chrono::seconds(producer_time));
	}
}

void Consumer(const int consumer_time) {
	while (is_consuming) {
		
		//创建信号量,对资源加锁
		unique_lock<mutex> lk(condition_mutex);
		produce_buffer.wait(lk, [] {              //等待信号,阻塞线程
			return !ware_house.empty();           //仓库不为空时返回 
		});

		//获得仓库所有权,取出产品
		Product prod = ware_house.front();
		ware_house.pop();
		prod_count--;
		cout << "Consumer --> product " << prod.prod_value 
			 << " inventory " << prod_count << endl;

		produce_buffer.notify_all(); //通知所有等待的条件变量
		lk.unlock(); //解除对资源的锁定

		//消费技能冷却
		std::this_thread::sleep_for(std::chrono::seconds(consumer_time));
	}
}

int main() {
	thread producer(Producer, 1);  //创建生产者线程,设置生产时间
	thread consumer(Consumer, 2);  //创建消费者线程,设置消费时间

	producer.join();
	consumer.join();
	return 0;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在C语言中实现多线程生产者消费者模型可以使用线程库pthread。下面是一个简单的示例代码: ```c #include <stdio.h> #include <stdlib.h> #include <pthread.h> #define BUFFER_SIZE 5 int buffer[BUFFER_SIZE]; int count = 0; // 缓冲区中的数据数量 pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER; // 互斥锁 pthread_cond_t empty = PTHREAD_COND_INITIALIZER; // 缓冲区为空的条件变量 pthread_cond_t full = PTHREAD_COND_INITIALIZER; // 缓冲区为满的条件变量 void* producer(void* arg) { int item; while (1) { item = rand() % 100; // 生成随机数作为生产的物品 pthread_mutex_lock(&mutex); // 加锁 while (count == BUFFER_SIZE) { // 如果缓冲区已满,等待 pthread_cond_wait(&empty, &mutex); } buffer[count++] = item; // 将物品放入缓冲区 printf("Producer produced item: %d\n", item); pthread_cond_signal(&full); // 唤醒等待的消费者 pthread_mutex_unlock(&mutex); // 解锁 } return NULL; } void* consumer(void* arg) { int item; while (1) { pthread_mutex_lock(&mutex); // 加锁 while (count == 0) { // 如果缓冲区为空,等待 pthread_cond_wait(&full, &mutex); } item = buffer[--count]; // 从缓冲区取出物品 printf("Consumer consumed item: %d\n", item); pthread_cond_signal(&empty); // 唤醒等待的生产者 pthread_mutex_unlock(&mutex); // 解锁 } return NULL; } int main() { pthread_t producer_thread, consumer_thread; pthread_create(&producer_thread, NULL, producer, NULL); pthread_create(&consumer_thread, NULL, consumer, NULL); pthread_join(producer_thread, NULL); pthread_join(consumer_thread, NULL); return 0; } ``` 这个示例代码中,定义了一个大小为5的缓冲区(使用数组实现),其中`count`变量表示缓冲区中的数据数量。生产者线程通过生成随机数作为物品,并将物品放入缓冲区。消费者线程从缓冲区中取出物品并进行消费。互斥锁`mutex`用于保护临界区资源的访问,条件变量`empty`和`full`用于实现生产者消费者之间的同步。 请注意,这只是一个简单的示例代码,没有考虑线程安全性和错误处理。在实际使用中,还需要更加细致的设计和处理。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值