thread_local

Struct CachedThreadLocal

Source
pub struct CachedThreadLocal<T: Send> { /* private fields */ }
👎Deprecated since 1.1.0: Use ThreadLocal instead
Expand description

Wrapper around ThreadLocal.

This used to add a fast path for a single thread, however that has been obsoleted by performance improvements to ThreadLocal itself.

Implementations§

Source§

impl<T: Send> CachedThreadLocal<T>

Source

pub fn new() -> CachedThreadLocal<T>

Creates a new empty CachedThreadLocal.

Source

pub fn get(&self) -> Option<&T>

Returns the element for the current thread, if it exists.

Source

pub fn get_or<F>(&self, create: F) -> &T
where F: FnOnce() -> T,

Returns the element for the current thread, or creates it if it doesn’t exist.

Source

pub fn get_or_try<F, E>(&self, create: F) -> Result<&T, E>
where F: FnOnce() -> Result<T, E>,

Returns the element for the current thread, or creates it if it doesn’t exist. If create fails, that error is returned and no element is added.

Source

pub fn iter_mut(&mut self) -> CachedIterMut<'_, T>

Returns a mutable iterator over the local values of all threads.

Since this call borrows the ThreadLocal mutably, this operation can be done safely—the mutable borrow statically guarantees no other threads are currently accessing their associated values.

Source

pub fn clear(&mut self)

Removes all thread-specific values from the ThreadLocal, effectively reseting it to its original state.

Since this call borrows the ThreadLocal mutably, this operation can be done safely—the mutable borrow statically guarantees no other threads are currently accessing their associated values.

Source§

impl<T: Send + Default> CachedThreadLocal<T>

Source

pub fn get_or_default(&self) -> &T

Returns the element for the current thread, or creates a default one if it doesn’t exist.

Trait Implementations§

Source§

impl<T: Send + Debug> Debug for CachedThreadLocal<T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<T: Send> Default for CachedThreadLocal<T>

Source§

fn default() -> CachedThreadLocal<T>

Returns the “default value” for a type. Read more
Source§

impl<'a, T: Send + 'a> IntoIterator for &'a mut CachedThreadLocal<T>

Source§

type Item = &'a mut T

The type of the elements being iterated over.
Source§

type IntoIter = CachedIterMut<'a, T>

Which kind of iterator are we turning this into?
Source§

fn into_iter(self) -> CachedIterMut<'a, T>

Creates an iterator from a value. Read more
Source§

impl<T: Send> IntoIterator for CachedThreadLocal<T>

Source§

type Item = T

The type of the elements being iterated over.
Source§

type IntoIter = CachedIntoIter<T>

Which kind of iterator are we turning this into?
Source§

fn into_iter(self) -> CachedIntoIter<T>

Creates an iterator from a value. Read more
Source§

impl<T: Send + UnwindSafe> UnwindSafe for CachedThreadLocal<T>

Auto Trait Implementations§

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, U> TryFrom<U> for T
where U: Into<T>,

Source§

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>,

Source§

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.

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 512 bytes