Crates.io | arc-atomic-ref |
lib.rs | arc-atomic-ref |
version | 1.0.0 |
source | src |
created_at | 2023-02-24 18:58:20.561857 |
updated_at | 2023-02-24 18:58:20.561857 |
description | arc-atomic-ref is a small library that wraps arc-swap in
Arc |
homepage | |
repository | https://github.com/bluecatengineering/arc-atomic-ref |
max_upload_size | |
id | 793848 |
size | 7,867 |
an AtomicRef
is a smart pointer type that can be shared with many
different threads of execution, while at the same time can be swapped out
atomically with new data. In this way, it's similar to a lock-free
RwLock
or Mutex
when you can replace the contained data rather than
modify it.
use arc_atomic_ref::AtomicRef;
use std::sync::Arc;
let ptr = AtomicRef::new(1);
// share ptr with many threads with `clone`
// change its contained value, requires a new `Arc`
ptr.swap(Arc::new(2));
// all threads should see the change, use `.load()` to get the value
assert_eq!(**ptr.load(), 2);