#reference-counting #arc #thread-safe #immutability #owned #cow

atomicow

A Cow-like data structure where owned data is stored inside an Arc

1 stable release

1.0.0 Aug 29, 2024

#609 in Data structures

Download history 4933/week @ 2024-09-22 5757/week @ 2024-09-29 5411/week @ 2024-10-06 3854/week @ 2024-10-13 3011/week @ 2024-10-20 3295/week @ 2024-10-27 4223/week @ 2024-11-03 3992/week @ 2024-11-10 3377/week @ 2024-11-17 5044/week @ 2024-11-24 10243/week @ 2024-12-01 8520/week @ 2024-12-08 8553/week @ 2024-12-15 7216/week @ 2024-12-22 9687/week @ 2024-12-29 10092/week @ 2025-01-05

36,578 downloads per month
Used in 301 crates (via bevy_asset)

MIT/Apache

10KB
166 lines

atomicow

A Cow-like data structure where owned data is stored inside an Arc. Here's what it looks like:

pub enum CowArc<'a, T: ?Sized + 'static> {
    Borrowed(&'a T),
    Static(&'static T),
    Owned(Arc<T>),
}

As implied by the Cow name, this type allows for cheap immutable reference, but can be converted into an owned form via cloning when mutation or ownership is required.

This data structure is particularly useful for str or other values with a static lifetime, as might be used in structures such as asset paths. A 'static str stored in a CowArc can be cloned without allocations or bookkeeping, while owned values are shared by reference-counting in a thread-safe fashion.

Comparison to the cow_arc crate

The similar cow_arc crate already exists. How does atomicow differ?

Put simply: cow_arc's data structure is just a wrapper over an Arc. While this is exactly what you need in some use cases, the enum structure used in atomicow is both more transparent and more flexible.

Contributing

This crate is maintained by the Bevy organization, and is intended to be tiny, stable, zero-dependency, and broadly useful. Issues and pull requests are genuinely welcome!

No runtime deps