多线程模拟消费者和生产者

主要思路:

生产者和消费者是经典的进程同步问题,在这个问题中生产者不断的向缓冲区中写入数据,而消费者则从缓冲区中读取数据。生产者进程和消费者对缓冲区的操作是互斥,即当前只能有一个进程对这个缓冲区进行操作,生产者进入操作缓冲区之前,先要看缓冲区是否已满,如果缓冲区已满,如果缓冲区已满,则它必须等待消费者进程将数据取出才能写入数据,同样的,消费者进程从缓冲区读取数据之前,也要判断缓冲区是否为空,如果为空,则必须等待生产者进程写入数据才能读取数据。

功能介绍:

模拟在线多生产和消费者的进程,生产者不断的往产品库中放入产品,而消费者不断的从产品库中取出产品,由于产品库的容量有限,只能容纳一定数量的产品,当生产者的速度过快的话,就需要等待消费,因此定义了生产者和消费者两个线程,并定义互斥锁,以免在缓冲区的共享资源会出现问题。

构造两个核心的方法

Void ConsumeItem(ItemRepository&itemRepo)

该方法主要是消费者对缓冲区的产品是否取出的交互,通过确定等待信号是否为空来对缓冲区中的产品进行操作,并与生产者对象进行互斥。

voidProduceItem(ItemRepository &itemRepo,intitem)

该方法是生产生产方法,首先在缓冲区检查是否为满,从而判断消费者是否需要等待,如果有等待的信号,程序就继续向下执行,如果没有,就一直等待。







  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值