2
0
Fork 1
mirror of https://github.com/async-rs/async-std.git synced 2025-01-19 20:13:51 +00:00
async-std/README.md

140 lines
4 KiB
Markdown
Raw Normal View History

<h1 align="center">async-std</h1>
<div align="center">
<strong>
Async version of the Rust standard library
</strong>
</div>
<br />
<div align="center">
<!-- Crates version -->
<a href="https://crates.io/crates/async-std">
<img src="https://img.shields.io/crates/v/async-std.svg?style=flat-square"
alt="Crates.io version" />
</a>
<!-- Downloads -->
<a href="https://crates.io/crates/async-std">
<img src="https://img.shields.io/crates/d/async-std.svg?style=flat-square"
alt="Download" />
</a>
<!-- docs.rs docs -->
<a href="https://docs.rs/async-std">
<img src="https://img.shields.io/badge/docs-latest-blue.svg?style=flat-square"
alt="docs.rs docs" />
</a>
<a href="https://discord.gg/JvZeVNe">
<img src="https://img.shields.io/discord/598880689856970762.svg?logo=discord&style=flat-square"
alt="chat" />
</a>
</div>
<div align="center">
<h3>
<a href="https://docs.rs/async-std">
API Docs
</a>
<span> | </span>
<a href="https://book.async.rs">
Book
</a>
<span> | </span>
<a href="https://github.com/async-rs/async-std/releases">
Releases
</a>
<span> | </span>
<a href="https://async.rs/contribute">
Contributing
</a>
</h3>
</div>
<br/>
This crate provides an async version of [`std`]. It provides all the interfaces
you are used to, but in an async version and ready for Rust's `async`/`await`
syntax.
2019-08-08 12:44:48 +00:00
[`std`]: https://doc.rust-lang.org/std/index.html
2019-08-15 13:27:25 +00:00
## Features
2019-08-15 13:27:25 +00:00
- __Modern:__ Built from the ground up for `std::future` and `async/await` with
2019-10-30 19:06:42 +00:00
blazing fast compilation time.
- __Fast:__ Our robust allocator and threadpool designs provide ultra-high
throughput with predictably low latency.
- __Intuitive:__ Complete parity with the stdlib means you only need to learn
APIs once.
- __Clear:__ [Detailed documentation][docs] and [accessible guides][book] mean
using async Rust was never easier.
2019-08-15 13:27:25 +00:00
2019-08-12 12:15:59 +00:00
[docs]: https://docs.rs/async-std
[book]: https://book.async.rs
2019-08-08 12:44:48 +00:00
## Examples
2019-08-08 12:44:48 +00:00
All examples require the [`"attributes"` feature] to be enabled. This feature
is not enabled by default because it significantly impacts compile times. See
[`task::block_on`] for an alternative way to start executing tasks.
2019-08-08 12:44:48 +00:00
```rust
async fn say_hello() {
println!("Hello, world!");
}
2019-08-08 12:44:48 +00:00
#[async_std::main]
async fn main() {
say_hello().await;
2019-08-08 12:44:48 +00:00
}
```
More examples, including networking and file access, can be found in our
[`examples`] directory and in our [documentation].
[`examples`]: https://github.com/async-rs/async-std/tree/master/examples
[documentation]: https://docs.rs/async-std#examples
[`task::block_on`]: task/fn.block_on.html
[`"attributes"` feature]: https://docs.rs/async-std/#features
2019-08-12 12:15:59 +00:00
## Philosophy
2019-08-12 12:15:59 +00:00
We believe Async Rust should be as easy to pick up as Sync Rust. We also believe
that the best API is the one you already know. And finally, we believe that
providing an asynchronous counterpart to the standard library is the best way
stdlib provides a reliable basis for both performance and productivity.
2019-08-12 12:15:59 +00:00
Async-std is the embodiment of that vision. It combines single-allocation task
creation, with an adaptive lock-free executor, threadpool and network driver to
create a smooth system that processes work at a high pace with low latency,
using Rust's familiar stdlib API.
2019-08-12 12:15:59 +00:00
## Installation
2019-08-12 12:15:59 +00:00
With [cargo add][cargo-add] installed run:
2019-08-12 12:15:59 +00:00
```sh
$ cargo add async-std
2019-08-12 12:15:59 +00:00
```
We also provide a set of "unstable" features with async-std. See the [features
documentation] on how to enable them.
2019-08-12 12:15:59 +00:00
[cargo-add]: https://github.com/killercup/cargo-edit
[features documentation]: https://docs.rs/async-std/#features
2019-08-12 12:15:59 +00:00
2019-08-08 12:44:48 +00:00
## License
<sup>
Licensed under either of <a href="LICENSE-APACHE">Apache License, Version
2.0</a> or <a href="LICENSE-MIT">MIT license</a> at your option.
</sup>
2019-08-08 12:44:48 +00:00
<br/>
2019-08-08 12:44:48 +00:00
<sub>
2019-08-08 12:44:48 +00:00
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in this crate by you, as defined in the Apache-2.0 license, shall
be dual licensed as above, without any additional terms or conditions.
</sub>