Struct once_cell::sync::Lazy [−][src]
pub struct Lazy<T, F = fn() -> T> { /* fields omitted */ }
A value which is initialized on the first access.
This type is thread-safe and can be used in statics.
Example
use std::collections::HashMap; use once_cell::sync::Lazy; static HASHMAP: Lazy<HashMap<i32, String>> = Lazy::new(|| { println!("initializing"); let mut m = HashMap::new(); m.insert(13, "Spica".to_string()); m.insert(74, "Hoyten".to_string()); m }); fn main() { println!("ready"); std::thread::spawn(|| { println!("{:?}", HASHMAP.get(&13)); }).join().unwrap(); println!("{:?}", HASHMAP.get(&74)); // Prints: // ready // initializing // Some("Spica") // Some("Hoyten") }
Implementations
impl<T, F> Lazy<T, F>
[src]
impl<T, F> Lazy<T, F>
[src]impl<T, F: FnOnce() -> T> Lazy<T, F>
[src]
impl<T, F: FnOnce() -> T> Lazy<T, F>
[src]pub fn force(this: &Lazy<T, F>) -> &T
[src]
Forces the evaluation of this lazy value and
returns a reference to the result. This is equivalent
to the Deref
impl, but is explicit.
Example
use once_cell::sync::Lazy; let lazy = Lazy::new(|| 92); assert_eq!(Lazy::force(&lazy), &92); assert_eq!(&*lazy, &92);
Trait Implementations
impl<T, F: RefUnwindSafe> RefUnwindSafe for Lazy<T, F> where
OnceCell<T>: RefUnwindSafe,
[src]
OnceCell<T>: RefUnwindSafe,
impl<T, F: Send> Sync for Lazy<T, F> where
OnceCell<T>: Sync,
[src]
OnceCell<T>: Sync,
Auto Trait Implementations
impl<T, F> Send for Lazy<T, F> where
F: Send,
T: Send,
F: Send,
T: Send,
impl<T, F> Unpin for Lazy<T, F> where
F: Unpin,
T: Unpin,
F: Unpin,
T: Unpin,
impl<T, F> UnwindSafe for Lazy<T, F> where
F: UnwindSafe,
T: UnwindSafe,
F: UnwindSafe,
T: UnwindSafe,