pub struct OnceNonZeroUsize { /* private fields */ }
Expand description
A thread-safe cell which can be written to only once.
Implementations§
Source§impl OnceNonZeroUsize
impl OnceNonZeroUsize
Sourcepub const fn new() -> OnceNonZeroUsize
pub const fn new() -> OnceNonZeroUsize
Creates a new empty cell.
Sourcepub fn get(&self) -> Option<NonZeroUsize>
pub fn get(&self) -> Option<NonZeroUsize>
Gets the underlying value.
Sourcepub unsafe fn get_unchecked(&self) -> NonZeroUsize
pub unsafe fn get_unchecked(&self) -> NonZeroUsize
Get the reference to the underlying value, without checking if the cell is initialized.
§Safety
Caller must ensure that the cell is in initialized state, and that the contents are acquired by (synchronized to) this thread.
Sourcepub fn set(&self, value: NonZeroUsize) -> Result<(), ()>
pub fn set(&self, value: NonZeroUsize) -> Result<(), ()>
Sets the contents of this cell to value
.
Returns Ok(())
if the cell was empty and Err(())
if it was
full.
Sourcepub fn get_or_init<F>(&self, f: F) -> NonZeroUsizewhere
F: FnOnce() -> NonZeroUsize,
pub fn get_or_init<F>(&self, f: F) -> NonZeroUsizewhere
F: FnOnce() -> NonZeroUsize,
Gets the contents of the cell, initializing it with f
if the cell was
empty.
If several threads concurrently run get_or_init
, more than one f
can
be called. However, all threads will return the same value, produced by
some f
.
Sourcepub fn get_or_try_init<F, E>(&self, f: F) -> Result<NonZeroUsize, E>
pub fn get_or_try_init<F, E>(&self, f: F) -> Result<NonZeroUsize, E>
Gets the contents of the cell, initializing it with f
if
the cell was empty. If the cell was empty and f
failed, an
error is returned.
If several threads concurrently run get_or_init
, more than one f
can
be called. However, all threads will return the same value, produced by
some f
.