#bitmap #bitvec #vec #heap-allocation

smallbitvec

A bit vector optimized for size and inline storage

19 stable releases

2.5.3 Mar 17, 2024
2.5.1 Aug 5, 2021
2.5.0 May 8, 2020
2.4.0 May 15, 2019
1.0.7 Sep 27, 2017

#44 in Data structures

Download history 20500/week @ 2024-10-05 16639/week @ 2024-10-12 19860/week @ 2024-10-19 17854/week @ 2024-10-26 19237/week @ 2024-11-02 17513/week @ 2024-11-09 19397/week @ 2024-11-16 12210/week @ 2024-11-23 16842/week @ 2024-11-30 16278/week @ 2024-12-07 14019/week @ 2024-12-14 7581/week @ 2024-12-21 8937/week @ 2024-12-28 18850/week @ 2025-01-04 21525/week @ 2025-01-11 13687/week @ 2025-01-18

64,067 downloads per month
Used in 17 crates (12 directly)

MIT/Apache

42KB
1K SLoC

smallbitvec

A bit vector that is the size of a pointer, and can store data either inline or on the heap. Like the bit-vec crate but optimized for small inline size and reduced allocations.


lib.rs:

SmallBitVec is a bit vector, a vector of single-bit values stored compactly in memory.

SmallBitVec grows dynamically, like the standard Vec<T> type. It can hold up to about one word of bits inline (without a separate heap allocation). If the number of bits exceeds this inline capacity, it will allocate a buffer on the heap.

Example

use smallbitvec::SmallBitVec;

let mut v = SmallBitVec::new();
v.push(true);
v.push(false);

assert_eq!(v[0], true);
assert_eq!(v[1], false);

No runtime deps