Wjybxx.Disruptor 1.1.1

dotnet add package Wjybxx.Disruptor --version 1.1.1                
NuGet\Install-Package Wjybxx.Disruptor -Version 1.1.1                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Wjybxx.Disruptor" Version="1.1.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Wjybxx.Disruptor --version 1.1.1                
#r "nuget: Wjybxx.Disruptor, 1.1.1"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Wjybxx.Disruptor as a Cake Addin
#addin nuget:?package=Wjybxx.Disruptor&version=1.1.1

// Install Wjybxx.Disruptor as a Cake Tool
#tool nuget:?package=Wjybxx.Disruptor&version=1.1.1                

Disruptor模块

LMAX-Disruptor的C#精简实现,保留其核心设计,更好的抽象和扩展性。

先上架构图:Disruptor架构图

与LMAX的Disruptor差异

  1. RingBuffer仅是数据结构,没有额外的职责。
  2. Sequencer是协调的集成,而不是生产者屏障,生产者屏障有明确的抽象。
  3. 协调的基本单位是屏障Barrier,依赖的单位也是屏障,而不是序列Sequence
  4. 反转了Barrier和Consumer之间的Sequence依赖。
  5. 剥离了Blocker和WaitStrategy,消费者可以使用不同的等待策略,但使用同一个Blocker。
  6. 库只提供了核心的协调功能,并没有提供BatchEventProcessor这样的具体组件,完全由用户控制。
  7. 内置了一套无界缓冲区MpUnboundedBuffer

ps: 很自信地讲,我的设计更容易理解。

C#实现与Java实现的不同

  1. C#的挂起最小单位是毫秒,而1毫秒已是非常长的时间,因此所有Sleep等待策略都没有让用户指定睡眠时间,而是固定1毫秒。
  2. C#的Thread.SpinWait方法提供了iterations参数,因此所有的SpinWait策略都提供了该参数支持。
  3. C#的不直接支持C++11的 Acquire和Release内存语义,因此使用Volatile读写代替。
  4. C#不支持volatile修饰64位的long和double,因此一些long类型字段未声明为volatile,这与我的日常习惯不同 -- 可能多线程读写的字段,保持为volatile是个好习惯。
  5. 为支持结构体类型,DataProvider提供了获取元素引用的ProducerGetRefConsumerGetRef接口。

PS:C#其实可以采用FieldOffset来实现缓存行填充,但为了保持代码简单,暂未采用

注意事项:

  1. C#的挂起最小单位是毫秒,因此慎重使用可能导致线程挂起的api,可能导致较大的延迟。
  2. 框架的具体应用见并发库中的DisruptorEventLoop

ReleaseNotes

1.1.1

  1. 修复TimeoutSleepingWaitStrategy在Windows上延迟过高的问题。
  2. 使用sequence-1代替抛出TimeoutException,C#的异常总是会影响性能,即使我们声明为不捕获异常的。
Product Compatible and additional computed target framework versions.
.NET net5.0 is compatible.  net5.0-windows was computed.  net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 is compatible.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net5.0

    • No dependencies.
  • net6.0

    • No dependencies.
  • net7.0

    • No dependencies.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on Wjybxx.Disruptor:

Package Downloads
Wjybxx.Commons.Concurrent

并发基础库;提供事件循环和基于事件循环的await语法

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.1.1 258 8/23/2024
1.1.0 168 8/21/2024