This project aims to provide the full functionality of the Disruptor to CLR projects.
There is no specific documentation for this project, but most of the information from the Java version is applicable to the .NET version, especially the core concepts.
- Include latest changes made to the future Java versions
- Remove exception-based APIs
- Improve documentation
28/04/2018 (v3.4.1):
- Fix invalid IL code that caused an exception on Mono
28/04/2018 (v3.4.0-alpha):
- Remove Histogram and MutableLong
- Remove base type from SingleProducerSequencer and MultiProducerSequencer
- Fix race between run() and halt() on BatchEventProcessor
- Make obsolete exception-based TryNext methods
- (Perf) Use generated struct types to improve BatchEventProcessor and ProcessingSequenceBarrier performance
- (Perf) Remove unneeded unsafe code from MultiProducerSequencer
- (Perf) Use custom IL to improve RingBuffer indexer performance
05/02/2018 (v3.3.8):
- Add exception free overloads to ISequenced.TryNext
- Revert belt and braces WaitStategy signalling.
02/11/2017 (v3.3.7):
- All features available in Java Disruptor 3.3.7 have been ported
- Drop .NET Core 1.1
- Add .NET Standard 2.0
02/05/2017 (v3.3.6):
- Support .NET Core 1.1
01/04/2017 (v3.3.6-alpha):
- All features available in Java Disruptor 3.3.6 have been ported
- Use an aggressive spin wait in all blocking wait strategies (#25)
- Add a new blocking low CPU usage wait strategy
02/08/2016 (v3.3.5):
- All features available in Java Disruptor 3.3.5 have been ported
04/07/2016 (v3.3.4):
- All features available in Java Disruptor 3.3.4 have been ported by the team at ABC Arbitrage
- Now targeting the .NET 4.6.1 framework and using C# 6 features
11/7/2013 (v2.10.0):
- All features available in Java Disruptor 2.10.0 have been ported
The quickest way to get started with the disruptor is by using the NuGet package
You may also build the Disruptor directly from the source:
- You need Visual Studio 2017
- run
Cake-Build.bat
, it will compile, run the tests and output binaries and results into\output\assembly
folder
You can also run all the performance tests by running Cake-Perf.bat
.
Copyright Olivier Deheurles
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this project except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.