pub struct LocalWaker { /* private fields */ }Expand description
A synchronization primitive for task wakeup.
Sometimes the task interested in a given event will change over time.
An LocalWaker can coordinate concurrent notifications with the consumer
potentially “updating” the underlying task to wake up. This is useful in
scenarios where a computation completes in another task and wants to
notify the consumer, but the consumer is in the process of being migrated to
a new logical task.
Consumers should call register before checking the result of a computation
and producers should call wake after producing the computation (this
differs from the usual thread::park pattern). It is also permitted for
wake to be called before register. This results in a no-op.
A single LocalWaker may be reused for any number of calls to register or
wake.
Implementations§
Source§impl LocalWaker
impl LocalWaker
Sourcepub fn register(&self, waker: &Waker) -> bool
pub fn register(&self, waker: &Waker) -> bool
Registers the waker to be notified on calls to wake.
Returns true if waker was registered before.
Sourcepub fn wake(&self)
pub fn wake(&self)
Calls wake on the last Waker passed to register.
If register has not been called yet, then this does nothing.
Sourcepub fn wake_checked(&self) -> bool
pub fn wake_checked(&self) -> bool
Calls wake on the last Waker passed to register.
If register has not been called yet, then this returns false.