futures_task

Struct 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§

Source§

impl<'a> WakerRef<'a>

Source

pub fn new(waker: &'a Waker) -> Self

Create a new WakerRef from a [Waker] reference.

Source

pub fn new_unowned(waker: ManuallyDrop<Waker>) -> Self

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>§

1.36.0

pub fn wake_by_ref(&self)

Wakes 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().

1.36.0

pub fn will_wake(&self, other: &Waker) -> bool

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 — for example, this type’s clone_from implementation uses it to avoid cloning the waker when they would wake the same task anyway.

1.83.0

pub fn data(&self) -> *const ()

Gets the data pointer used to create this Waker.

1.83.0

pub fn vtable(&self) -> &'static RawWakerVTable

Gets the vtable pointer used to create this Waker.

Trait Implementations§

Source§

impl<'a> Debug for WakerRef<'a>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Deref for WakerRef<'_>

Source§

type Target = Waker

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Waker

Dereferences the value.

Auto Trait Implementations§

§

impl<'a> Freeze for WakerRef<'a>

§

impl<'a> RefUnwindSafe for WakerRef<'a>

§

impl<'a> Send for WakerRef<'a>

§

impl<'a> Sync for WakerRef<'a>

§

impl<'a> Unpin for WakerRef<'a>

§

impl<'a> UnwindSafe for WakerRef<'a>

Blanket Implementations§

§

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

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

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

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

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

§

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

Mutably borrows from an owned value. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

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

§

fn into(self) -> U

Calls U::from(self).

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

§

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

§

type Error = Infallible

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

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

Performs the conversion.
§

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

§

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

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

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

Performs the conversion.