Struct may::LocalKey

source ·
pub struct LocalKey<T> { /* private fields */ }
Expand description

A key for local data stored in a coroutine.

This type is generated by the coroutine_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 coroutine, and the data is destroyed when the coroutine is completed.

coroutine-local data requires the 'static bound to ensure it lives long enough. When a key is accessed for the first time the coroutine’s data is initialized with the provided initialization expression to the macro.

Implementations§

source§

impl<T: 'static> LocalKey<T>

source

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

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

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

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

if it’s not accessed in a coroutine context, it will use the thread local storage as a backend, so it’s safe to use it in thread context

§Panics

This function can possibly panic for a number of reasons:

  • If the initialization expression is run and it panics
  • If the closure provided panics

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§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Pointable for T

source§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

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

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.