15 releases
0.4.2 | Oct 31, 2024 |
---|---|
0.4.1 | Jun 30, 2024 |
0.3.7 | Oct 11, 2023 |
0.3.6 | Sep 18, 2023 |
0.1.0 | Aug 3, 2023 |
#448 in Asynchronous
Used in photohash
38KB
737 lines
async MPMC channel that reduces overhead by reading and writing many values at once.
Sometimes large volumes of small values are farmed out to workers through a channel. Consider directory traversal: each readdir() call produces a batch of directory entries. Batching can help the consumption side too. Consider querying SQLite with received values -- larger batches reduce the amortized cost of acquiring SQLite's lock and bulk queries can be issued.
One can imagine natural, currently unimplemented, extensions to this crate:
- Channels with priority
- impls for
futures::sink::Sink
andfutures::stream::Stream
Ask if they would be helpful.
Dependencies
~0.4–24MB
~349K SLoC