生产者消费者模式理解

2 篇文章 0 订阅

说到这个模式大家都很熟悉,但是要真正的运用到项目中需要认真考虑一下几个问题:

1:数据处理能力

      因为此模式需要设置一个缓冲区来缓存数据,所以生产者生产的数据超过了缓冲区大小,则需要抛弃掉。如果你设计的系统需要实时处理数据,并且保证数据不会被抛弃掉,这个设计模式那就不太适合。

2:缓冲区线程同步

     基本上是采用一个生产者线程和一个消费者线程来处理数据,这就涉及到缓冲区队列线程安全的问题,如果这个问题没有处理好,则会导致一些意想不到的BUG。

3:生产速度和消费速度

    如果生产者速度过快,那么缓冲区就会有大量数据等待处理,造成程序内存不断上涨,也会导致生产的数据因为来不及处理,没有加入到队列(队列有上限设置),数据被抛弃。

    如果是消费者处理速度过快则不会出现什么问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值