Struct arc_swap::gen_lock::PrivateUnsharded
source · pub struct PrivateUnsharded { /* private fields */ }
Expand description
A single „shard“ that is stored inline, inside the corresponding ArcSwap
. Therefore, locks on
each instance won’t influence any other instances. On the other hand, the ArcSwap
itself gets
bigger and doesn’t have multiple shards, so concurrent uses might contend each other a bit.
// This one shares locks with others.
let shared = ArcSwap::from_pointee(42);
// But this one has an independent lock.
let independent = ArcSwapAny::<Arc<usize>, PrivateUnsharded>::from_pointee(42);
// This'll hold a lock so any writers there wouldn't complete
let l = independent.load_signal_safe();
// But the lock doesn't influence the shared one, so this goes through just fine
shared.store(Arc::new(43));
assert_eq!(42, **l);
Note that theres a type alias [
IndependentArcSwap`](../type.IndependentArcSwap.html) that can
be used instead.
Trait Implementations§
source§impl Default for PrivateUnsharded
impl Default for PrivateUnsharded
source§fn default() -> PrivateUnsharded
fn default() -> PrivateUnsharded
Returns the “default value” for a type. Read more
source§impl LockStorage for PrivateUnsharded
impl LockStorage for PrivateUnsharded
source§fn gen_idx(&self) -> &AtomicUsize
fn gen_idx(&self) -> &AtomicUsize
Access to the generation index. Read more
source§fn choose_shard(&self) -> usize
fn choose_shard(&self) -> usize
Pick one shard of the all selected. Read more