Struct TaskHandle

Source
pub struct TaskHandle<T> { /* private fields */ }
Expand description

A handle to a spawned task

A TaskHandle can be awaited to wait for the completion of its associated task and get its result.

A TaskHandle detaches its task when dropped. This means the it can no longer be awaited, but the executor will still poll its task.

This is created by Executor::spawn and Executor::spawn_rc.

Implementations§

Source§

impl<T> TaskHandle<T>

Source

pub fn cancel(&self)

Cancel the task

Deletes the task from the executor so that it won’t be polled again.

If the handle is awaited after cancellation, it might still complete if the task was already finished before it was cancelled. However, the likelier outcomes is that it never completes.

Source

pub fn is_finished(&self) -> bool

Check if this task is finished

If this returns true, the next poll call is guaranteed to return Poll::Ready.

Source

pub fn is_cancelled(&self) -> bool

Check if this task has been cancelled

Trait Implementations§

Source§

impl<T> Future for TaskHandle<T>

Source§

type Output = T

The type of value produced on completion.
Source§

fn poll(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output>

Attempts to resolve the future to a final value, registering the current task for wakeup if the value is not yet available. Read more

Auto Trait Implementations§

§

impl<T> Freeze for TaskHandle<T>

§

impl<T> !RefUnwindSafe for TaskHandle<T>

§

impl<T> !Send for TaskHandle<T>

§

impl<T> !Sync for TaskHandle<T>

§

impl<T> Unpin for TaskHandle<T>

§

impl<T> !UnwindSafe for TaskHandle<T>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<F> IntoFuture for F
where F: Future,

Source§

type Output = <F as Future>::Output

The output that the future will produce on completion.
Source§

type IntoFuture = F

Which kind of future are we turning this into?
Source§

fn into_future(self) -> <F as IntoFuture>::IntoFuture

Creates a future from a value. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<F, T, E> TryFuture for F
where F: Future<Output = Result<T, E>> + ?Sized,

Source§

type Ok = T

The type of successful values yielded by this future
Source§

type Error = E

The type of failures yielded by this future
Source§

fn try_poll( self: Pin<&mut F>, cx: &mut Context<'_>, ) -> Poll<<F as Future>::Output>

Poll this TryFuture as if it were a Future. Read more
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.