async-oneshot

License Package Documentation

A fast and small async-aware oneshot channel.

Features:

Usage

```rust

[test]

fn successonethread() { let (s,r) = oneshot::(); asserteq!((), s.send(true).unwrap()); asserteq!(Ok(true), future::block_on(r)); } ```

Performance

Here are benchmark numbers on my Ryzen 9 3900X:

test create ... bench: 56 ns/iter (+/- 2) test create_send ... bench: 55 ns/iter (+/- 5) test create_send_recv ... bench: 42 ns/iter (+/- 0) test create_wait_send_recv ... bench: 109 ns/iter (+/- 3)

Here are the same benchmarks on my 2015 macbook pro:

test create ... bench: 122 ns/iter (+/- 12) test create_send ... bench: 122 ns/iter (+/- 21) test create_send_recv ... bench: 126 ns/iter (+/- 8) test create_wait_send_recv ... bench: 232 ns/iter (+/- 29)

Most of the time is actually taken up by measurement overhead and the last bench is probably benching futures_lite::future::block_on more than it's benching this library. We are, in short, very fast.

Compared to other libraries

The oneshot channel in futures isn't very fast by comparison.

Tokio put up an excellent fight and made us work hard to improve. In general I'd say we're slightly faster overall, but it's incredibly tight.

Note on safety

Yes, this crate uses unsafe. 10 times. Not all of it is performance gaming. Please audit carefully!

See Also

Copyright and License

Copyright (c) 2020 James Laver, async-oneshot contributors.

This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0. If a copy of the MPL was not distributed with this file, You can obtain one at http://mozilla.org/MPL/2.0/.