#channel #mpmc #select #golang #message

crossbeam-channel

Multi-producer multi-consumer channels for message passing

9 releases

0.2.4 Aug 2, 2018
0.2.3 Jul 20, 2018
0.2.1 Jun 12, 2018
0.1.3 May 23, 2018
0.1.1 Nov 27, 2017

#17 in Concurrency

Download history 8786/week @ 2018-09-05 13654/week @ 2018-09-12 17124/week @ 2018-09-19 15879/week @ 2018-09-26 18850/week @ 2018-10-03 22535/week @ 2018-10-10 20903/week @ 2018-10-17 18001/week @ 2018-10-24 20657/week @ 2018-10-31 19327/week @ 2018-11-07 21430/week @ 2018-11-14 22489/week @ 2018-11-21 19153/week @ 2018-11-28

16,131 downloads per month
Used in 272 crates (63 directly)

MIT/Apache

403KB
7K SLoC

Crossbeam Channel

Build Status License Cargo Documentation Rust 1.26+

This crate provides multi-producer multi-consumer channels for message passing. It is an alternative to std::sync::mpsc with more features and better performance.

Some highlights:

  • Senders and Receivers can be cloned and shared among threads.
  • Two main kinds of channels are unbounded and bounded.
  • Convenient extra channels like after, never, and tick.
  • The select! macro can block on multiple channel operations.
  • Select can select over a dynamically built list of channel operations.
  • Channels use locks very sparingly for maximum performance.

Usage

Add this to your Cargo.toml:

[dependencies]
crossbeam-channel = "0.3"

Next, add this to your crate:

#[macro_use]
extern crate crossbeam_channel;

Compatibility

The minimum supported Rust version is 1.26.

This crate does not work in no_std environments.

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Third party software

This product includes copies and modifications of software developed by third parties:

  • examples/matching.rs includes matching.go by Stefan Nilsson, licensed under Creative Commons Attribution 3.0 Unported License.

  • src/flavors/array.rs is based on Bounded MPMC queue by Dmitry Vyukov, licensed under the Simplified BSD License and the Apache License, Version 2.0.

  • tests/mpsc.rs includes modifications of code from The Rust Programming Language, licensed under the MIT License and the Apache License, Version 2.0.

  • tests/golang.rs is based on code from The Go Programming Language, licensed under the 3-Clause BSD License.

See the source code files for more details.

Copies of third party licenses can be found in LICENSE-THIRD-PARTY.

Dependencies

~1.5MB
~21K SLoC