10 releases

0.1.8 Jul 13, 2024
0.1.7 Jul 6, 2023
0.1.6 Jun 21, 2023
0.1.5 Mar 28, 2023
0.0.1 Feb 18, 2023

#161 in Concurrency

Download history 1408/week @ 2024-10-06 1845/week @ 2024-10-13 920/week @ 2024-10-20 1058/week @ 2024-10-27 1386/week @ 2024-11-03 1210/week @ 2024-11-10 1292/week @ 2024-11-17 1901/week @ 2024-11-24 1599/week @ 2024-12-01 1657/week @ 2024-12-08 1670/week @ 2024-12-15 921/week @ 2024-12-22 667/week @ 2024-12-29 1885/week @ 2025-01-05 1894/week @ 2025-01-12 1505/week @ 2025-01-19

6,042 downloads per month
Used in 18 crates (via eyeball)

MPL-2.0 license

19KB
255 lines

readlock

(Shared) Read-Only Lock: A thing that can be useful when you don't really want shared mutability, you just want to mutate a value from one place and read it from many others.

This library provides three types:

  • Shared<T>: similar to Arc<RwLock<T>>, but you can only create SharedReadLock<T>s and WeakReadLock<T>s from it that share access to the same inner value, not further Shared<T>s. Also, acquiring a write lock requires unique ownership / borrowing (&mut self). However: Reading requires no locking because mutably borrowing the Shared means that no other thread can be mutating the value at the same time (all other reference to the value are read-only).
  • SharedReadLock<T>: like a Arc<RwLock<T>> that is only ever used for reading. Can be downgraded to WeakReadLock.
  • WeakReadLock<T>: like a Weak<RwLock<T>>. That is, it references the same memory, but if the original Shared and any derived SharedReadLocks to that value are dropped, it will be deallocated regardless of any WeakReadLocks. Must be upgraded into SharedReadLock to access the inner value.

Dependencies

~15KB