Async I/O and timers
Find a file
Repository files (latest commit first)
Filename Latest commit message Latest commit date
2026-06-01 21:48:28 +02:00
benches Update criterion requirement from 0.4 to 0.6 (#226) 2025-07-26 15:09:18 +09:00
examples Fix clippy::uninlined_format_args warning 2025-07-19 22:46:24 +09:00
src chore: sync dependencies (monorepo) 2026-03-30 09:26:21 +02:00
tests Use std::future::poll_fn instead of futures_lite::future::poll_fn 2025-08-10 13:48:21 +09:00
.cirrus.yml ci: Install ca_root_nss for FreeBSD CI 2026-03-15 19:38:29 -07:00
.gitignore Initial commit 2020-06-28 22:15:55 +02:00
build.rs impl IoSafe for std::io::PipeReader & std::io::PipeWriter (#237) 2025-08-05 20:37:56 +09:00
Cargo.toml fix: use git.sly.so/kade for forkable deps 2026-06-01 21:48:28 +02:00
LICENSE-APACHE More info about the project 2020-06-29 16:26:06 +02:00
LICENSE-MIT More info about the project 2020-06-29 16:26:06 +02:00
README.md Fix build badge (#197) 2024-09-14 17:37:50 +09:00

async-io

Build License Cargo Documentation

Async I/O and timers.

This crate provides two tools:

  • Async, an adapter for standard networking types (and many other types) to use in async programs.
  • Timer, a future that expires at a point in time.

For concrete async networking types built on top of this crate, see async-net.

Implementation

The first time Async or Timer is used, a thread named "async-io" will be spawned. The purpose of this thread is to wait for I/O events reported by the operating system, and then wake appropriate futures blocked on I/O or timers when they can be resumed.

To wait for the next I/O event, the "async-io" thread uses epoll on Linux/Android/illumos, kqueue on macOS/iOS/BSD, event ports on illumos/Solaris, and IOCP on Windows. That functionality is provided by the polling crate.

However, note that you can also process I/O events and wake futures on any thread using the block_on() function. The "async-io" thread is therefore just a fallback mechanism processing I/O events in case no other threads are.

Examples

Connect to example.com:80, or time out after 10 seconds.

use async_io::{Async, Timer};
use futures_lite::{future::FutureExt, io};

use std::net::{TcpStream, ToSocketAddrs};
use std::time::Duration;

let addr = "example.com:80".to_socket_addrs()?.next().unwrap();

let stream = Async::<TcpStream>::connect(addr).or(async {
    Timer::after(Duration::from_secs(10)).await;
    Err(io::ErrorKind::TimedOut.into())
})
.await?;

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.