Struct std::lazy::SyncOnceCell
pub struct SyncOnceCell<T> { /* fields omitted */ }
A synchronization primitive which can be written to only once.
This type is a thread-safe OnceCell
.
Examples
#![feature(once_cell)] use std::lazy::SyncOnceCell; static CELL: SyncOnceCell<String> = SyncOnceCell::new(); assert!(CELL.get().is_none()); std::thread::spawn(|| { let value: &String = CELL.get_or_init(|| { "Hello, World!".to_string() }); assert_eq!(value, "Hello, World!"); }).join().unwrap(); let value: Option<&String> = CELL.get(); assert!(value.is_some()); assert_eq!(value.unwrap().as_str(), "Hello, World!");
Implementations
impl<T> SyncOnceCell<T>
pub const fn new() -> SyncOnceCell<T>
Creates a new empty cell.
pub fn get(&self) -> Option<&T>
Gets the reference to the underlying value.
Returns None
if the cell is empty, or being initialized. This method never blocks.
pub fn get_mut(&mut self) -> Option<&mut T>
Gets the mutable reference to the underlying value.
Returns None
if the cell is empty. This method never blocks.
pub fn set(&self, value: T) -> Result<(), T>
Sets the contents of this cell to value
.
May block if another thread is currently attempting to initialize the cell. The cell is guaranteed to contain a value when set returns, though not necessarily the one provided.
Returns Ok(())
if the cell’s value was set by this call.
Examples
#![feature(once_cell)] use std::lazy::SyncOnceCell; static CELL: SyncOnceCell<i32> = SyncOnceCell::new(); fn main() { assert!(CELL.get().is_none()); std::thread::spawn(|| { assert_eq!(CELL.set(92), Ok(())); }).join().unwrap(); assert_eq!(CELL.set(62), Err(62)); assert_eq!(CELL.get(), Some(&92)); }
Gets the contents of the cell, initializing it with f
if the cell was empty.
Many threads may call get_or_init
concurrently with different initializing functions, but it is guaranteed that only one function will be executed.
Panics
If f
panics, the panic is propagated to the caller, and the cell remains uninitialized.
It is an error to reentrantly initialize the cell from f
. The exact outcome is unspecified. Current implementation deadlocks, but this may be changed to a panic in the future.
Examples
#![feature(once_cell)] use std::lazy::SyncOnceCell; let cell = SyncOnceCell::new(); let value = cell.get_or_init(|| 92); assert_eq!(value, &92); let value = cell.get_or_init(|| unreachable!()); assert_eq!(value, &92);
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.
Panics
If f
panics, the panic is propagated to the caller, and the cell remains uninitialized.
It is an error to reentrantly initialize the cell from f
. The exact outcome is unspecified. Current implementation deadlocks, but this may be changed to a panic in the future.
Examples
#![feature(once_cell)] use std::lazy::SyncOnceCell; let cell = SyncOnceCell::new(); assert_eq!(cell.get_or_try_init(|| Err(())), Err(())); assert!(cell.get().is_none()); let value = cell.get_or_try_init(|| -> Result<i32, ()> { Ok(92) }); assert_eq!(value, Ok(&92)); assert_eq!(cell.get(), Some(&92))
pub fn into_inner(self) -> Option<T>
Consumes the SyncOnceCell
, returning the wrapped value. Returns None
if the cell was empty.
Examples
#![feature(once_cell)] use std::lazy::SyncOnceCell; let cell: SyncOnceCell<String> = SyncOnceCell::new(); assert_eq!(cell.into_inner(), None); let cell = SyncOnceCell::new(); cell.set("hello".to_string()).unwrap(); assert_eq!(cell.into_inner(), Some("hello".to_string()));
pub fn take(&mut self) -> Option<T>
Takes the value out of this SyncOnceCell
, moving it back to an uninitialized state.
Has no effect and returns None
if the SyncOnceCell
hasn’t been initialized.
Safety is guaranteed by requiring a mutable reference.
Examples
#![feature(once_cell)] use std::lazy::SyncOnceCell; let mut cell: SyncOnceCell<String> = SyncOnceCell::new(); assert_eq!(cell.take(), None); let mut cell = SyncOnceCell::new(); cell.set("hello".to_string()).unwrap(); assert_eq!(cell.take(), Some("hello".to_string())); assert_eq!(cell.get(), None);
Trait Implementations
impl<T: Clone> Clone for SyncOnceCell<T>
fn clone(&self) -> SyncOnceCell<T>
Returns a copy of the value. Read more
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source
. Read more
impl<T: Debug> Debug for SyncOnceCell<T>
fn fmt(&self, f: &mut Formatter<'_>) -> Result
Formats the value using the given formatter. Read more
impl<T> Default for SyncOnceCell<T>
fn default() -> SyncOnceCell<T>
Creates a new empty cell.
Example
#![feature(once_cell)] use std::lazy::SyncOnceCell; fn main() { assert_eq!(SyncOnceCell::<()>::new(), SyncOnceCell::default()); }
impl<T> Drop for SyncOnceCell<T>
impl<T> From<T> for SyncOnceCell<T>
fn from(value: T) -> Self
Create a new cell with its contents set to value
.
Example
#![feature(once_cell)] use std::lazy::SyncOnceCell; let a = SyncOnceCell::from(3); let b = SyncOnceCell::new(); b.set(3)?; assert_eq!(a, b); Ok(())
impl<T: PartialEq> PartialEq<SyncOnceCell<T>> for SyncOnceCell<T>
fn eq(&self, other: &SyncOnceCell<T>) -> bool
This method tests for self
and other
values to be equal, and is used by ==
. Read more
fn ne(&self, other: &Rhs) -> bool
This method tests for !=
.
impl<T: Eq> Eq for SyncOnceCell<T>
impl<T: RefUnwindSafe + UnwindSafe> RefUnwindSafe for SyncOnceCell<T>
impl<T: Send> Send for SyncOnceCell<T>
impl<T: Sync + Send> Sync for SyncOnceCell<T>
impl<T: UnwindSafe> UnwindSafe for SyncOnceCell<T>
Auto Trait Implementations
impl<T> Unpin for SyncOnceCell<T> where
T: Unpin,
Blanket Implementations
impl<T> From<!> for T
pub fn from(t: !) -> T
Performs the conversion.
impl<T> From<T> for T
pub fn from(t: T) -> T
Performs the conversion.
pub fn into(self) -> U
Performs the conversion.
type Owned = T
The resulting type after obtaining ownership.
pub fn to_owned(&self) -> T
Creates owned data from borrowed data, usually by cloning. Read more
pub fn clone_into(&self, target: &mut T)
toowned_clone_into
#41263)recently added
Uses borrowed data to replace owned data, usually by cloning. Read more
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
Performs the conversion.
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
Performs the conversion.
© 2010 The Rust Project Developers
Licensed under the Apache License, Version 2.0 or the MIT license, at your option.
https://doc.rust-lang.org/std/lazy/struct.SyncOnceCell.html