Struct futures_util::task::WakerRef

source ·
pub struct WakerRef<'a> { /* private fields */ }
Expand description

A Waker that is only valid for a given lifetime.

Note: this type implements Deref<Target = Waker>, so it can be used to get a &Waker.

Implementations§

Create a new WakerRef from a Waker reference.

Create a new WakerRef from a Waker that must not be dropped.

Note: this if for rare cases where the caller created a Waker in an unsafe way (that will be valid only for a lifetime to be determined by the caller), and the Waker doesn’t need to or must not be destroyed.

Methods from Deref<Target = Waker>§

Wake up the task associated with this Waker without consuming the Waker.

This is similar to wake(), but may be slightly less efficient in the case where an owned Waker is available. This method should be preferred to calling waker.clone().wake().

Returns true if this Waker and another Waker would awake the same task.

This function works on a best-effort basis, and may return false even when the Wakers would awaken the same task. However, if this function returns true, it is guaranteed that the Wakers will awaken the same task.

This function is primarily used for optimization purposes.

🔬This is a nightly-only experimental API. (waker_getters)

Get a reference to the underlying RawWaker.

Trait Implementations§

Formats the value using the given formatter. Read more
The resulting type after dereferencing.
Dereferences the value.

Auto Trait Implementations§

Blanket Implementations§

Gets the TypeId of self. Read more
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

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

The type returned in the event of a conversion error.
Performs the conversion.
The type returned in the event of a conversion error.
Performs the conversion.