[][src]Struct futures::task::LocalKey

pub struct LocalKey<T> { /* fields omitted */ }

A key for task-local data stored in a future's task.

This type is generated by the task_local! macro and performs very similarly to the thread_local! macro and std::thread::LocalKey types. Data associated with a LocalKey<T> is stored inside of a future's task, and the data is destroyed when the future is completed and the task is destroyed.

Task-local data can migrate between threads and hence requires a Send bound. Additionally, task-local data also requires the 'static bound to ensure it lives long enough. When a key is accessed for the first time the task's data is initialized with the provided initialization expression to the macro.

Methods

impl<T: Send + 'static> LocalKey<T>[src]

pub fn with<F, R>(&'static self, f: F) -> R where
    F: FnOnce(&T) -> R, 
[src]

Access this task-local key, running the provided closure with a reference to the value.

This function will access this task-local key to retrieve the data associated with the current task and this key. If this is the first time this key has been accessed on this task, then the key will be initialized with the initialization expression provided at the time the task_local! macro was called.

The provided closure will be provided a shared reference to the underlying data associated with this task-local-key. The data itself is stored inside of the current task.

Panics

This function can possibly panic for a number of reasons:

  • If there is not a current task.
  • If the initialization expression is run and it panics
  • If the closure provided panics

Trait Implementations

impl<T: Debug> Debug for LocalKey<T>[src]

Auto Trait Implementations

impl<T> RefUnwindSafe for LocalKey<T>

impl<T> Send for LocalKey<T>

impl<T> Sync for LocalKey<T>

impl<T> Unpin for LocalKey<T>

impl<T> UnwindSafe for LocalKey<T>

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.