Struct rayon_core::WorkerLocal
source · pub struct WorkerLocal<T> { /* private fields */ }
Expand description
Holds worker-locals values for each thread in a thread pool. You can only access the worker local value through the Deref impl on the thread pool it was constructed on. It will panic otherwise
Implementations§
source§impl<T> WorkerLocal<T>
impl<T> WorkerLocal<T>
sourcepub fn new<F: FnMut(usize) -> T>(initial: F) -> WorkerLocal<T>
pub fn new<F: FnMut(usize) -> T>(initial: F) -> WorkerLocal<T>
Creates a new worker local where the initial
closure computes the
value this worker local should take for each thread in the thread pool.
sourcepub fn into_inner(self) -> Vec<T>
pub fn into_inner(self) -> Vec<T>
Returns the worker-local value for each thread
Trait Implementations§
source§impl<T: Debug> Debug for WorkerLocal<T>
impl<T: Debug> Debug for WorkerLocal<T>
source§impl<T> Deref for WorkerLocal<T>
impl<T> Deref for WorkerLocal<T>
impl<T: Send> Sync for WorkerLocal<T>
We prevent concurrent access to the underlying value in the Deref impl, thus any values safe to send across threads can be used with WorkerLocal.