双缓冲安全队列(DoubleCacheQueue)与自旋锁(SpinMutex)

原文转自:http://www.tanjp.com/archives/144(即时修正和更新)双缓冲安全队列(DoubleCacheQueue)双缓冲区,故名思义就是要有两个缓冲区(简称A和B)。这两缓冲区,总是一个用于生产者,另一个用于消费者。当缓冲区触发某个条件时,进行一次切换(先前被生产者写入的转为消费者取出,先前消费者取出的转为生产者写入)。而这个触发的条件,一般是以快速消...
摘要由CSDN通过智能技术生成

原文转自:http://www.tanjp.com (即时修正和更新)

 

双缓冲安全队列(DoubleCacheQueue)

双缓冲区,故名思义就是要有两个缓冲区(简称A和B)。这两缓冲区,总是一个用于生产者,另一个用于消费者。当缓冲区触发某个条件时,进行一次切换(先前被生产者写入的转为消费者取出,先前消费者取出的转为生产者写入)。而这个触发的条件,一般是以快速消费完为主导(避免内存堆积太多数据),所以一般当消费缓冲区为空时,就触发交换。由于生产者和消费者不会同时操作同一个缓冲区(不发生冲突),所以就不需要在读写每一个数据单元的时候都进行同步/互斥操作。

PS: 多线程安全,当生产或消费的速度不平衡时,交换次数较少,能很明显提高性能

部分代码实现:

 

template<typename tpType>
class DoubleCacheQueue
{
    	typedef std::queue< tpType > Queue;
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值