LINUX系统编程:基于阻塞队列的生产者消费者模型

目录

1.什么是生产者消费者模型

2. 生产者消费者模型的理解

2.1为什么要对公共区域做保护

2.2角色之间的关系

2.3为什有生产者消费者模型、

3.实现代码

blockqueue.hpp

Main.cc


1.什么是生产者消费者模型

它是时一个经典的多线程并发的协作模型,也就是生产者(线程)向一个公共区域(阻塞队列)生产,生产出的“商品”被消费者(线程)消费。

其中生产者可以拥有多个,消费者可以拥有多个,但是公共区域只有一个。

2. 生产者消费者模型的理解

2.1为什么要对公共区域做保护

公共区域也被称为临界区,都知道要对临界区做保护,但是为什么呢?

例:

1.生产者向公共区域生产的时候,刚生产了一半,就被消费者拿走了,这就造成了数据不一致的问题。

2.公共的区域是有一定的容量限制的,当公共区域只剩下一个空位的时候,第一个生产者看到有一个空位,准备生产,但是在刚要生产的时候,cpu切换到第二个线程,第二个线程也看到有一个空位,也准备生产,这就产生了过度生产的问题,同样消费也会过度消费。

所以公共区域只能由,同一时间只能一个线程访问(阻塞队列是这样的,其他的不一定)。

2.2角色之间的关系

生产者与生产者 (<

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值