#vec #pin #pinned-vec

pinned_vec

Vec-like data structure whose elements never move

2 releases

0.1.1 Nov 25, 2021
0.1.0 Nov 25, 2021

#977 in Data structures

Download history 39/week @ 2025-01-07 151/week @ 2025-01-14 41/week @ 2025-01-21 32/week @ 2025-01-28 77/week @ 2025-02-04 110/week @ 2025-02-11 22/week @ 2025-02-18 25/week @ 2025-02-25 35/week @ 2025-03-04 100/week @ 2025-03-11 126/week @ 2025-03-18 19/week @ 2025-03-25 38/week @ 2025-04-01 68/week @ 2025-04-08 445/week @ 2025-04-15 3148/week @ 2025-04-22

3,701 downloads per month
Used in 3 crates (2 directly)

MPL-2.0 license

9KB
180 lines

PinnedVec

crates.io crates.io

Vec-like structure whose elements never move.

Normal Vec holds all its content in one contigious region, and moves when it needs to expand. PinnedVec holds several smaller sub-vector, each of which never moves. The first sub-vector is of capacity 1, the second 2, the third 4, the nth 2^(n-1).

Example Usage

use pinned_vec::PinnedVec;
use std::pin::Pin;
let mut v = PinnedVec::new();
v.push(5);
{
	let r: Pin<&i32> = v.get(0).unwrap();
	assert_eq!(*r, 5);
}
{
	let r: Pin<&mut i32> = v.get_mut(0).unwrap();
	assert_eq!(*r, 5);
}
assert_eq!(v.len(), 1);
v.pop();
v.push(7);
v.push(8);
v.replace(0, 6);
assert_eq!(*v.get(0).unwrap(), 6);
assert_eq!(*v.get(1).unwrap(), 8);

No runtime deps