Struct core::task::LocalWaker [−][src]
#[repr(transparent)]pub struct LocalWaker { /* fields omitted */ }
🔬 This is a nightly-only experimental API. (futures_api
#50547)
futures in libcore are unstable
A LocalWaker
is a handle for waking up a task by notifying its executor that it
is ready to be run.
This is similar to the Waker
type, but cannot be sent across threads.
Task executors can use this type to implement more optimized singlethreaded wakeup
behavior.
Methods
impl LocalWaker
[src]
impl LocalWaker
pub unsafe fn new(inner: NonNull<UnsafeWake>) -> Self
[src]
pub unsafe fn new(inner: NonNull<UnsafeWake>) -> Self
🔬 This is a nightly-only experimental API. (futures_api
#50547)
futures in libcore are unstable
Constructs a new LocalWaker
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 LocalWaker::from
function instead which works with the safe
Rc
type and the safe LocalWake
trait.
For this function to be used safely, it must be sound to call inner.wake_local()
on the current thread.
pub fn wake(&self)
[src]
pub fn wake(&self)
🔬 This is a nightly-only experimental API. (futures_api
#50547)
futures in libcore are unstable
Wake up the task associated with this LocalWaker
.
pub fn will_wake(&self, other: &LocalWaker) -> bool
[src]
pub fn will_wake(&self, other: &LocalWaker) -> bool
🔬 This is a nightly-only experimental API. (futures_api
#50547)
futures in libcore are unstable
Returns whether or not this LocalWaker
and other
LocalWaker
awaken the same task.
This function works on a best-effort basis, and may return false even
when the LocalWaker
s would awaken the same task. However, if this function
returns true, it is guaranteed that the LocalWaker
s will awaken the same
task.
This function is primarily used for optimization purposes.
pub fn will_wake_nonlocal(&self, other: &Waker) -> bool
[src]
pub fn will_wake_nonlocal(&self, other: &Waker) -> bool
🔬 This is a nightly-only experimental API. (futures_api
#50547)
futures in libcore are unstable
Returns whether or not this LocalWaker
and other
Waker
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 LocalWaker
s will awaken the same
task.
This function is primarily used for optimization purposes.
Trait Implementations
impl !Send for LocalWaker
[src]
impl !Send for LocalWaker
impl !Sync for LocalWaker
[src]
impl !Sync for LocalWaker
impl From<LocalWaker> for Waker
[src]
impl From<LocalWaker> for Waker
fn from(local_waker: LocalWaker) -> Self
[src]
fn from(local_waker: LocalWaker) -> Self
Performs the conversion.
impl Clone for LocalWaker
[src]
impl Clone for LocalWaker
fn clone(&self) -> Self
[src]
fn clone(&self) -> Self
Returns a copy of the value. Read more
fn clone_from(&mut self, source: &Self)
1.0.0[src]
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source
. Read more
impl Debug for LocalWaker
[src]
impl Debug for LocalWaker
fn fmt(&self, f: &mut Formatter) -> Result
[src]
fn fmt(&self, f: &mut Formatter) -> Result
Formats the value using the given formatter. Read more
impl Drop for LocalWaker
[src]
impl Drop for LocalWaker