Module futures::task

source ·
Expand description

Tools for working with tasks.

This module contains:

  • Spawn, a trait for spawning new tasks.
  • Context, a context of an asynchronous task, including a handle for waking up the task.
  • Waker, a handle for waking up a task.

The remaining types and traits in the module are used for implementing executors or dealing with synchronization issues around task wakeup.

Structs§

  • A synchronization primitive for task wakeup.
  • The context of an asynchronous task.
  • A custom trait object for polling futures, roughly akin to Box<dyn Future<Output = T> + Send + 'a>.
  • A custom trait object for polling futures, roughly akin to Box<dyn Future<Output = T> + 'a>.
  • A RawWaker allows the implementor of a task executor to create a Waker which provides customized wakeup behavior.
  • A virtual function pointer table (vtable) that specifies the behavior of a RawWaker.
  • An error that occurred during spawning.
  • A Waker is a handle for waking up a task by notifying its executor that it is ready to be run.
  • A Waker that is only valid for a given lifetime.

Enums§

  • Indicates whether a value is available or if the current task has been scheduled to receive a wakeup instead.

Traits§

  • A way of waking up a specific task.
  • The LocalSpawn is similar to Spawn, but allows spawning futures that don’t implement Send.
  • Extension trait for LocalSpawn.
  • The Spawn trait allows for pushing futures onto an executor that will run them to completion.
  • Extension trait for Spawn.
  • A custom implementation of a future trait object for FutureObj, providing a vtable with drop support.

Functions§

  • Create a new Waker which does nothing when wake() is called on it.
  • Get a static reference to a Waker which does nothing when wake() is called on it.
  • Creates a Waker from an Arc<impl ArcWake>.
  • Creates a reference to a Waker from a reference to Arc<impl ArcWake>.