Rust
Futures and Async IO
Szukaj…
Wprowadzenie
futures-rs to biblioteka, która implementuje zerowe koszty futures i strumieni w Rust.
Te podstawowe koncepcje terminowym skrzyni są Future i Stream .
Tworzenie przyszłości dzięki funkcji oneshot
Istnieją pewne ogólne implementacje cechy Future
w skrzynce przyszłości . Jeden z nich jest zaimplementowany w module futures::sync::oneshot
i jest dostępny poprzez funkcję futures::oneshot
:
extern crate futures;
use std::thread;
use futures::Future;
fn expensive_computation() -> u32 {
// ...
200
}
fn main() {
// The oneshot function returns a tuple of a Sender and a Receiver.
let (tx, rx) = futures::oneshot();
thread::spawn(move || {
// The complete method resolves a values.
tx.complete(expensive_computation());
});
// The map method applies a function to a value, when it is resolved.
let rx = rx.map(|x| {
println!("{}", x);
});
// The wait method blocks current thread until the value is resolved.
rx.wait().unwrap();
}
Modified text is an extract of the original Stack Overflow Documentation
Licencjonowany na podstawie CC BY-SA 3.0
Nie związany z Stack Overflow