Suche…


Einführung

futures-rs ist eine Bibliothek, die Zero-Cost-Futures und Streams in Rust implementiert.

Die Kernkonzepte der Zukunft Kiste sind Zukunft und Strom .

Zukunft mit der Oneshot-Funktion erstellen

In der Futures- Kiste gibt es einige allgemeine Implementierungen von Future Merkmalen. Eine davon ist im Modul futures::sync::oneshot implementiert und über die Funktion futures::oneshot verfügbar:

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
Lizenziert unter CC BY-SA 3.0
Nicht angeschlossen an Stack Overflow