Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/matklad/once_cell
Rust library for single assignment cells and lazy statics without macros
https://github.com/matklad/once_cell
lazy-evaluation rust
Last synced: 1 day ago
JSON representation
Rust library for single assignment cells and lazy statics without macros
- Host: GitHub
- URL: https://github.com/matklad/once_cell
- Owner: matklad
- License: apache-2.0
- Created: 2018-08-02T00:00:59.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-10-05T16:17:44.000Z (3 months ago)
- Last Synced: 2025-01-10T10:32:10.764Z (2 days ago)
- Topics: lazy-evaluation, rust
- Language: Rust
- Homepage:
- Size: 441 KB
- Stars: 1,902
- Watchers: 20
- Forks: 109
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE-APACHE
Awesome Lists containing this project
README
[![Build Status](https://github.com/matklad/once_cell/actions/workflows/ci.yaml/badge.svg)](https://github.com/matklad/once_cell/actions)
[![Crates.io](https://img.shields.io/crates/v/once_cell.svg)](https://crates.io/crates/once_cell)
[![API reference](https://docs.rs/once_cell/badge.svg)](https://docs.rs/once_cell/)# Overview
`once_cell` provides two new cell-like types, `unsync::OnceCell` and `sync::OnceCell`. `OnceCell`
might store arbitrary non-`Copy` types, can be assigned to at most once and provide direct access
to the stored contents. In a nutshell, API looks *roughly* like this:```rust
impl OnceCell {
fn new() -> OnceCell { ... }
fn set(&self, value: T) -> Result<(), T> { ... }
fn get(&self) -> Option<&T> { ... }
}
```Note that, like with `RefCell` and `Mutex`, the `set` method requires only a shared reference.
Because of the single assignment restriction `get` can return an `&T` instead of `Ref`
or `MutexGuard`.`once_cell` also has a `Lazy` type, build on top of `OnceCell` which provides the same API as
the `lazy_static!` macro, but without using any macros:```rust
use std::{sync::Mutex, collections::HashMap};
use once_cell::sync::Lazy;static GLOBAL_DATA: Lazy>> = Lazy::new(|| {
let mut m = HashMap::new();
m.insert(13, "Spica".to_string());
m.insert(74, "Hoyten".to_string());
Mutex::new(m)
});fn main() {
println!("{:?}", GLOBAL_DATA.lock().unwrap());
}
```More patterns and use-cases are in the [docs](https://docs.rs/once_cell/)!
# Related crates
* [double-checked-cell](https://github.com/niklasf/double-checked-cell)
* [lazy-init](https://crates.io/crates/lazy-init)
* [lazycell](https://crates.io/crates/lazycell)
* [mitochondria](https://crates.io/crates/mitochondria)
* [lazy_static](https://crates.io/crates/lazy_static)
* [async_once_cell](https://crates.io/crates/async_once_cell)
* [generic_once_cell](https://crates.io/crates/generic_once_cell) (bring your own mutex)Parts of `once_cell` API are included into `std` [as of Rust 1.70.0](https://github.com/rust-lang/rust/pull/105587).