#channel #message #mpmc #golang #select

no-std crossbeam-channel

Multi-producer multi-consumer channels for message passing

31 releases

0.5.14 Dec 15, 2024
0.5.13 May 19, 2024
0.5.12 Feb 28, 2024
0.5.10 Dec 24, 2023
0.1.1 Nov 27, 2017

#44 in Concurrency

Download history 1557978/week @ 2024-09-28 1563875/week @ 2024-10-05 1573248/week @ 2024-10-12 1604795/week @ 2024-10-19 1542175/week @ 2024-10-26 1509408/week @ 2024-11-02 1546192/week @ 2024-11-09 1594885/week @ 2024-11-16 1340878/week @ 2024-11-23 1570864/week @ 2024-11-30 1687550/week @ 2024-12-07 1683380/week @ 2024-12-14 839719/week @ 2024-12-21 992927/week @ 2024-12-28 1706202/week @ 2025-01-04 1539520/week @ 2025-01-11

5,331,449 downloads per month
Used in 8,168 crates (1,311 directly)

MIT/Apache

360KB
6K SLoC

Crossbeam Channel

Build Status License Cargo Documentation Rust 1.60+ chat

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 bounded and unbounded.
  • 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.5"

Compatibility

Crossbeam Channel supports stable Rust releases going back at least six months, and every time the minimum supported Rust version is increased, a new minor version is released. Currently, the minimum supported Rust version is 1.60.

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.

  • 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