1 unstable release

Uses old Rust 2015

0.3.0 Aug 16, 2019
0.2.3 Aug 15, 2019
0.2.2 Jun 26, 2017
0.2.1 May 7, 2016
0.1.0 Oct 7, 2015

#615 in Concurrency

Download history 2050/week @ 2024-08-18 2994/week @ 2024-08-25 2713/week @ 2024-09-01 3248/week @ 2024-09-08 2585/week @ 2024-09-15 2472/week @ 2024-09-22 2622/week @ 2024-09-29 2751/week @ 2024-10-06 3064/week @ 2024-10-13 2942/week @ 2024-10-20 2761/week @ 2024-10-27 2524/week @ 2024-11-03 3734/week @ 2024-11-10 4033/week @ 2024-11-17 2951/week @ 2024-11-24 3624/week @ 2024-12-01

14,628 downloads per month
Used in 44 crates (28 directly)

MIT/Apache

17KB
390 lines

spmc

Build Status

Single-Producer, Multiple-Consumer channel for Rust.

Documentation

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.


lib.rs:

SPMC

A single producer, multiple consumers. Commonly used to implement work-stealing.

Example

let (mut tx, rx) = spmc::channel();

let mut handles = Vec::new();
for n in 0..5 {
    let rx = rx.clone();
    handles.push(thread::spawn(move || {
        let msg = rx.recv().unwrap();
        println!("worker {} recvd: {}", n, msg);
    }));
}

for i in 0..5 {
    tx.send(i * 2).unwrap();
}

for handle in handles {
  handle.join().unwrap();
}

No runtime deps