LMAX 的中断器模式:是否有要C++的端口?
LMAX's disruptor pattern: is there a port to C++?
LMAX的Disruptor模式有开源的Java和。net版本,如视频LMAX -如何在小于1ms的延迟下实现100K TPS所述。这里有更多关于破坏者模式的信息链接。
有没有人知道将Disruptor模式移植到c++,无论是完成还是在测试中?
显然其他人正在呼吁c++版本的Disruptor模式
是的,已经有一个功能的c++移植。参见http://www.2robots.com/2011/08/13/a-c-disruptor/。
从上面的链接("others are calling.."),注释:
讨论破坏者模式即将到来的c++移植的线程:http://groups.google.com/group/lmax-disruptor/browse_thread/thread/4a47a0a9b5837ca2
c++版本Disruptor的性能:大约。每秒2200万条消息,批处理达到每秒1亿条消息,参见:http://mechanical-sympathy.blogspot.com/2011/08/inter-thread-latency.html
有一个叫做hmbdc-base的免费版本。可以从以下目录下载的RPM:
https://bitbucket.org/hmbd/hmbdc-rel/downloads它支持CentOS 7,并且不依赖于虚拟函数,亚微秒级延迟,非常快。
它还具有可靠的订阅/发布多播消息传递支持。
相关文章:
- 在提升multi_index容器中,是否定义了"default index"?
- 在C++STL中是否有Polyval(Matlab函数)等价物?
- 检查输入是否不是整数或数字
- 是否可以初始化不可复制类型的成员变量(或基类)
- 在C++中,是否可以基于给定的标识符创建基类的新实例,反之亦然
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 此代码是否违反一个定义规则
- 是否需要删除包含对象的"pair"?
- 是否可以从int转换为enum类类型
- 无论条件是否为true,if总是在c++中执行
- 如何找到大小'x'数组是否完全填充,在C++?
- 检查值是否在集合p1和p2中,但不在p3中
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 检查 std::shared_ptr<> 的当前底层类型是否为 T
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- GL_SHADERSTORAGE_BUFFER位置是否与其他着色器位置冲突
- 子目录是否继承属性,例如add_definitions,include_directories和父Cmakelist.t
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- C/C++预处理器是否可以检测一些编译器选项
- 是否可以用"iostream"包装现有的TCP/OOpenSSL会话