#rcu #lockless #atomic

no-std rcu_cell

a lockless rcu cell implementation

12 releases

Uses old Rust 2015

0.1.11 Mar 9, 2023
0.1.10 Apr 7, 2021
0.1.8 Jun 23, 2019
0.1.7 Apr 2, 2019
0.1.2 Sep 28, 2018

⚠️ Issues reported

#177 in Concurrency

Download history 7/week @ 2024-01-07 1/week @ 2024-01-14 83/week @ 2024-02-25 34/week @ 2024-03-03 21/week @ 2024-03-10 18/week @ 2024-03-17 10/week @ 2024-03-24 39/week @ 2024-03-31 10/week @ 2024-04-07 6/week @ 2024-04-14 4/week @ 2024-04-21

59 downloads per month
Used in 7 crates (via ate)

LGPL-3.0

18KB
428 lines

Build Status Current Crates.io Version Document

RcuCell

A lockless rcu cell implementation that can be used safely in multithread context.

Features

  • The write operation would not block the read operation.
  • The write operation would "block" the write operation.
  • The RcuCell could contain no data

Usage

   fn single_thread() {
        let t = RcuCell::new(Some(10));
        let x = t.read();
        let y = t.read();
        t.try_lock().unwrap().update(None);
        let z = t.read();
        let a = z.clone();
        drop(t); // t can be dropped before reader
        assert_eq!(x.map(|v| *v), Some(10));
        assert_eq!(y.map(|v| *v), Some(10));
        assert_eq!(z.map(|v| *v), None);
        assert_eq!(a.map(|v| *v), None);
    }

No runtime deps