每天学习一算法系列(31)(实现一个队列,队列的应用场景为:一个生产者线程将int 类型的数入列,一个消费者线程将int 类型的数出列)

该博客介绍了如何使用PV操作来实现一个并发队列,适用于一个生产者线程入列int类型数据,一个消费者线程出列数据的场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目:

实现一个队列。
队列的应用场景为:一个生产者线程将int 类型的数入列,一个消费者线程将int 类型的数出列。

 

思路一:

这就是操作系统中介绍的PV操作,队列的一个典型的应用模式。实现这个PV操作的过程中要注意两个线程之间的通信就可以了。

 

代码如下:

/*-----------------------------
Copyright by yuucyf. 2011.08.25
-------------------------------*/

#include "stdafx.h"
#include <windows.h>
#include <stdio.h>
#include <process.h>
#include <iostream>
#include <queue>
using namespace std;

HANDLE g_hSemaphore = NULL;		//信号量
const int g_i32PMax = 100;		//生产(消费)总数
std::queue<int> g_queuePV;		//生产入队,消费出队


//生产者线程
unsigned int __stdcall ProducerThread(void* pParam)
{
	int i32N = 0;
	while (++i32N <= g_i32PMax)
	{
		//生产
		g_queuePV.push(i32N);
		cout<<"Produce "&l
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值