Struct thread_local::ThreadLocal
source · pub struct ThreadLocal<T: Send> { /* private fields */ }
Expand description
Thread-local variable wrapper
See the module-level documentation for more.
Implementations§
source§impl<T: Send> ThreadLocal<T>
impl<T: Send> ThreadLocal<T>
sourcepub fn new() -> ThreadLocal<T>
pub fn new() -> ThreadLocal<T>
Creates a new empty ThreadLocal
.
sourcepub fn with_capacity(capacity: usize) -> ThreadLocal<T>
pub fn with_capacity(capacity: usize) -> ThreadLocal<T>
Creates a new ThreadLocal
with an initial capacity. If less than the capacity threads
access the thread local it will never reallocate. The capacity may be rounded up to the
nearest power of two.
sourcepub fn get_or<F>(&self, create: F) -> &Twhere
F: FnOnce() -> T,
pub fn get_or<F>(&self, create: F) -> &Twhere F: FnOnce() -> T,
Returns the element for the current thread, or creates it if it doesn’t exist.
sourcepub fn get_or_try<F, E>(&self, create: F) -> Result<&T, E>where
F: FnOnce() -> Result<T, E>,
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.
sourcepub fn iter(&self) -> Iter<'_, T> ⓘwhere
T: Sync,
pub fn iter(&self) -> Iter<'_, T> ⓘwhere T: Sync,
Returns an iterator over the local values of all threads in unspecified order.
This call can be done safely, as T
is required to implement Sync
.
sourcepub fn iter_mut(&mut self) -> IterMut<'_, T> ⓘ
pub fn iter_mut(&mut self) -> IterMut<'_, T> ⓘ
Returns a mutable iterator over the local values of all threads in unspecified order.
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.
sourcepub fn clear(&mut self)
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> ThreadLocal<T>
impl<T: Send + Default> ThreadLocal<T>
sourcepub fn get_or_default(&self) -> &T
pub fn get_or_default(&self) -> &T
Returns the element for the current thread, or creates a default one if it doesn’t exist.