C++无锁(lock free)队列moodycamel::ConcurrentQueue

moodycamel::ConcurrentQueue介绍

moodycamel::ConcurrentQueue一个用C++11实现的多生产者、多消费者无锁队列。
它具有以下特点:
1.快的让人大吃一惊,详见不同无锁队列之间的压测对比
2.单头文件实现,很容易集成到你的项目中
3.完全线程安全的无锁队列,支持任意线程数的并发
4.用C++11实现,尽可能move元素,而不是copy元素
5.模板化,无需专门处理指针,内部自动管理内存
6.对元素类型或最大计数没有人为限制
7.内存可以预先一次分配,也可以根据需要动态分配
8.跨平台,所有操作都通过标准C++11原语完成
9.支持超快批量操作
10.包括低开销阻塞版本(BlockingConcurrentQueue)
11.异常安全
现实中,很少见到用C++实现的完全无锁队列。Boost有一个——boost::lockfree::queue,但它仅限于具有简单赋值运算符和简单析构函数的对象。Intel的TBB(tbb::concurrent_queue)队列不是无锁的,也需要简单的构造函数。有许多学术论文声称用C++实现了无锁队列,但很难找到可用的源代码,对源码的测试就更难找到了。
这个队列不仅比其他队列(在大多数情况下)具有更少的限制,而且速度更快。它经过了良好的测试,并提供了诸如批量入队/出队等高级功能。
简而言之,在C++开源世界中有一个关于无锁队列的空白,我用我所能做到的最快、最完整、测试良

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值