[][src]Struct futures::task::WakerRef

pub struct WakerRef<'a> { /* fields omitted */ }

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

impl<'a> WakerRef<'a>[src]

pub fn new(waker: &'a Waker) -> WakerRef<'a>[src]

Create a new WakerRef from a Waker reference.

pub fn new_unowned(waker: ManuallyDrop<Waker>) -> WakerRef<'a>[src]

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>

pub fn wake_by_ref(&self)1.36.0[src]

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

pub fn will_wake(&self, other: &Waker) -> bool1.36.0[src]

Returns true if this Waker and another Waker have awoken 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.

Trait Implementations

impl<'a> Debug for WakerRef<'a>[src]

impl<'_> Deref for WakerRef<'_>[src]

type Target = Waker

The resulting type after dereferencing.

Auto Trait Implementations

impl<'a> RefUnwindSafe for WakerRef<'a>[src]

impl<'a> Send for WakerRef<'a>[src]

impl<'a> Sync for WakerRef<'a>[src]

impl<'a> Unpin for WakerRef<'a>[src]

impl<'a> UnwindSafe for WakerRef<'a>[src]

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.