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