Struct once_cell::race::OnceNonZeroUsize
source · 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 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>where
F: FnOnce() -> Result<NonZeroUsize, E>,
pub fn get_or_try_init<F, E>(&self, f: F) -> Result<NonZeroUsize, E>where F: FnOnce() -> 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
.
Trait Implementations§
source§impl Debug for OnceNonZeroUsize
impl Debug for OnceNonZeroUsize
source§impl Default for OnceNonZeroUsize
impl Default for OnceNonZeroUsize
source§fn default() -> OnceNonZeroUsize
fn default() -> OnceNonZeroUsize
Returns the “default value” for a type. Read more