[−][src]Struct futures::task::Waker
🔬 This is a nightly-only experimental API. (futures_api
)
futures in libcore are unstable
A Waker
is a handle for waking up a task by notifying its executor that it
is ready to be run.
This handle contains a trait object pointing to an instance of the UnsafeWake
trait, allowing notifications to get routed through it.
Methods
impl Waker
[src]
pub unsafe fn new(inner: NonNull<dyn UnsafeWake + 'static>) -> Waker
[src]
🔬 This is a nightly-only experimental API. (futures_api
)
futures in libcore are unstable
Constructs a new Waker
directly.
Note that most code will not need to call this. Implementers of the
UnsafeWake
trait will typically provide a wrapper that calls this
but you otherwise shouldn't call it directly.
If you're working with the standard library then it's recommended to
use the Waker::from
function instead which works with the safe
Arc
type and the safe Wake
trait.
pub fn wake(&self)
[src]
🔬 This is a nightly-only experimental API. (futures_api
)
futures in libcore are unstable
Wake up the task associated with this Waker
.
pub fn will_wake(&self, other: &Waker) -> bool
[src]
🔬 This is a nightly-only experimental API. (futures_api
)
futures in libcore are unstable
Returns whether or not this Waker
and other
awaken the same task.
This function works on a best-effort basis, and may return false even
when the Waker
s would awaken the same task. However, if this function
returns true, it is guaranteed that the Waker
s will awaken the same
task.
This function is primarily used for optimization purposes.
pub fn will_wake_local(&self, other: &LocalWaker) -> bool
[src]
🔬 This is a nightly-only experimental API. (futures_api
)
futures in libcore are unstable
Returns whether or not this Waker
and other
LocalWaker
awaken
the same task.
This function works on a best-effort basis, and may return false even
when the Waker
s would awaken the same task. However, if this function
returns true, it is guaranteed that the Waker
s will awaken the same
task.
This function is primarily used for optimization purposes.
Trait Implementations
impl Unpin for Waker
[src]
impl Sync for Waker
[src]
impl Send for Waker
[src]
impl Clone for Waker
[src]
fn clone(&self) -> Waker
[src]
fn clone_from(&mut self, source: &Self)
1.0.0[src]
Performs copy-assignment from source
. Read more
impl From<LocalWaker> for Waker
[src]
fn from(local_waker: LocalWaker) -> Waker
[src]
Converts a LocalWaker
into a Waker
.
This conversion turns a !Sync
LocalWaker
into a Sync
Waker
, allowing a wakeup
object to be sent to another thread, but giving up its ability to do specialized
thread-local wakeup behavior.
impl Debug for Waker
[src]
impl Drop for Waker
[src]
impl<T> From<Arc<T>> for Waker where
T: Wake + 'static,
[src]
T: Wake + 'static,
Blanket Implementations
impl<T> From for T
[src]
impl<T, U> Into for T where
U: From<T>,
[src]
U: From<T>,
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
impl<T, U> TryFrom for T where
T: From<U>,
[src]
T: From<U>,
type Error = !
try_from
)The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T> Borrow for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T, U> TryInto for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
try_from
)The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,